一、Git和SVN的对比:
1)Git是分布式的,SVN是集中式;
2)Git每个历史版本存储完整的文件,SVN存储文件的差异;
3)Git可离线完成大部分操作,SVN则必须与中央服务器进行网络交互;
4)Git有着优雅的分支和合并功能;
5)Git有着更强的撤销修改和修改版本历史的能力;
6)Git速度更快,效率更好;
二、Git安装:
git version 查看git的版本
§ 建议大家先在GitHub上面注册一个账号
1.添加user.name和user.email
git config --global user.name fyuan925 #fuyuan925是用户名
git config --global user.email fyuan925@gmail.com #fyuan925@gmail.com
2. 得到user.name/user.email
git config user.name
git config user.email
3.添加一个新的user.name
git config --global --add user.name kgc
4.得到属性的值
git config user.name
git config --get user.name
5.得到全局所有属性的值
git config --list --global
6.删除一个属性,并且是指定属性名进行删除
git config --global --unset user.name kgc
git config --list --global
7.当只有一个属性值的时候,我们可以在删除时不指定值
git config --global --unset user.name
git config --list --global
git config --global user.name fyuan925
git config --list --global
三、Git命令的基本使用:
1) add
2) commit
前提:知道当前版本是哪个, HEAD表示当前版本
回退到上一个版本: HEAD^ 一个^就表是前一个版本, 如果N个前版本可以用HEAD~N
回退:git reset --hard HEAD^
回退之后你后悔了又想回到后退之前的那个版本: git reset --hard xxxxxxxxx
xxxxxxxxx 前面可以通过 git log filename
3commit <== HEAD
2commit
1commit
执行了git reset --hard HEAD^之后
3commit
2commit <== HEAD
1commit
Git管理的是修改,而不是文件
撤销修改:没有提交到暂存区时,其实就在工作区: git checkout -- file
已经提交到暂存区了: 分两步:1)git reset HEAD file 2)git checkout -- file
删除文件:手误删除,如何恢复: git checkout -- file
真删除版本库的文件:1) git rm file
2) git commit -m ‘xxx‘
四、Git远程操作之添加远程库
git remote add origin git@github.com:fangyuan925/kgc_git.git
git push -u origin master
git push 就是把当前分支(master)推送到远程
-u:第一次推送到master分支时,要设置了,后续就不需要再使用-u了
git push origin master
§ 执行get push时出现错误及解决办法:
当执行命令git push -u origin master时报如下错误
解决办法:git remote set-url origin https://fdd8@github.com/fdd8/kgc_git.git,即在网址中添加GitHub的用户名即可。 再执行命令git push -u origin master时,就不会报错
1)先有本地仓库,后有远程仓库
git remote add origin git@github.com:fangyuan925/kgc_git.git
git push -u origin master
第一次使用-u,后面不再使用
2)先有远程仓库,再clone到本地(最常见的,一般都是先在GitHub上创建仓库,然后开发人员再clone到本地)
git clone xxxxxx
git push -u origin master
第一次使用-u,后面不再使用
五、Git远程操作之添加远程库具体操作步骤
一、生成ssh,在GitHub上设置公钥
生成ssh:ssh-keygen -t rsa -C ‘kgc@gmail.com‘
进入ssh目录:cd ssh
将ssh目录下文件id_rsa.pub里的内容拷贝出来
二、在GitHub上设置ssh的公钥
1).进入GitHub主页,点击右上角settings
2).选择SSH and GPG keys进行公钥设置
3).点击右上角New SSH key新建一个ssh key,Title自定义,将CentOS中生成的公钥拷贝出来,粘贴到Key中,点击Add SSH key添加ssh key
4).输入GitHub的密码进行验证,点击Confirm password
三、在GitHub上创建仓库
1).点击右上角+,选择New repository新建仓库
2).填写仓库名称,点击Create repository创建仓库
四、与远程库建立连接
git remote add origin git@github.com:fangyuan925/kgc_git.git
git push -u origin master
git push 就是把当前分支(master)推送到远程
-u:第一次推送到master分支时,要设置了,后续就不需要再使用-u了
git push origin master
执行get push时出现错误及解决办法:
当执行命令git push -u origin master时报如下错误
解决办法:git remote set-url origin https://fdd8@github.com/fdd8/kgc_git.git,即在网址中添加GitHub的用户名即可。再执行命令git push -u origin master时,就不会报错
§ 推荐学习:Git快速入门版本,你可以点击 Git简明指南 查看。
Git 完整命令手册地址:http://git-scm.com/docs
PDF 版命令手册:github-git-cheat-sheet.pdf
原文:https://www.cnblogs.com/yutianbao/p/9191772.html