说明:本次总结来自廖雪峰的官方网站,仅供学习,如有侵权请联系管理员删除。
git命令
安装git
安装完成后需要配置姓名和电子邮箱 git config --global user.name "Your Name"
git config --global user.email "[email protected]"
初始化仓库
在一个工程根目录输入git init把目录变成Git仓库。
初始化一个Git仓库,使用git init命令。
把文件添加到仓库
添加文件到Git仓库,分两步:
第一步,使用命令git add ,注意,可反复多次使用,添加多个文件;
第二步,使用命令git commit,完成
查看修改的记录和状态
要随时掌握工作区的状态,使用git status命令。
如果git status告诉你有文件被修改过,用git diff可以查看修改内容
用git diff HEAD -- readme.txt命令可以查看工作区和版本库里面最新版本的区别
回退到指定版本
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id(版本ID)每个版本都有一个唯一的id。
git reset --hard HARD^ 返回上一个版本。
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。
工作区和版本库
工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。
每次修改,如果不add到暂存区,那就不会加入到commit中。
https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013745374151782eb658c5a5ca454eaa451661275886c6000
撤销修改
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。
删除文件
命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
要从版本库中删除该文件,那就用命令git rm删掉,并且git commit:
$ git rm test.txt
rm 'test.txt'
$ git commit -m "remove test.txt"
[master d17efd8] remove test.txt
1 file changed, 1 deletion(-)
delete mode 100644 test.txt
现在,文件就从版本库中被删除了。
git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”,前提是版本库中文件没有被删除。
$ git checkout -- test.txt
上传本地库到github
首先注册github账户
在本地生成SSH秘钥
ssh-keygen -t rsa -C "[email protected]"
如果出问题可以清除所有的SSH从新配置一次
ssh-add -D
rm -r ~/.ssh
可以在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。
3.登陆GitHub,打开“Account settings”,“SSH Keys”页面:
然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容
本地仓库和github关联
首先在github新建一个仓库,然后在本地执行
git remote add origin [email protected]:name/仓库名.git
如果已经关联可以使用git remote rm origin删除已关联的远程仓库,从新关联。
把本地分支推送到github
git push origin master(分支名)
此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改
从github克隆到本地库
要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。
Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。
$ git clone [email protected]:用户名/仓库名.git
分支
解决合并冲突
删除带<<<<<<<,=======,>>>>>>>标识
或者、先把自己的文件还原然后在合并,在添加自己修改的代码。
用git log --graph命令可以看到分支合并图。
git log --graph --pretty=oneline --abbrev-commit
分支管理策略
通常,合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息。
如果要强制禁用Fast forward模式,Git就会在合并时生成一个新的commit,这样,从分支历史上就可以看出分支信息。
下面我们实战一下--no-ff方式的git merge:
首先,仍然创建并切换dev分支:
$ git checkout -b devSwitched to a new branch 'dev'
修改readme.txt文件,并提交一个新的commit:
$ git add readme.txt
$ git commit -m "add merge"
[dev 6224937] add merge
1 file changed, 1 insertion(+)
现在,我们切换回master:
$ git checkout masterSwitched to branch 'master'
准备合并dev分支,请注意--no-ff参数,表示禁用Fast forward:
$ git merge --no-ff -m "merge with no-ff" devMerge made by the 'recursive' strategy.
readme.txt | 1 +
1 file changed, 1 insertion(+)
因为本次合并要创建一个新的commit,所以加上-m参数,把commit描述写进去。
合并后,我们用git log看看分支历史:
$ git log --graph --pretty=oneline --abbrev-commit
* 7825a50 merge with no-ff
|\
| * 6224937 add merge
|/
* 59bc1cb conflict fixed
...
分支策略
在实际开发中,我们应该按照几个基本原则进行分支管理:
首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;
那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;
你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。
所以,团队合作的分支看起来就像这样:
小结
Git分支十分强大,在团队开发中应该充分应用。
合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。
BUG分支
修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除;
当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug,修复后,再git stash pop,回到工作现场。
新功能分支开发一个新feature,最好新建一个分支;
如果要丢弃一个没有被合并过的分支,可以通过git branch -D 强行删除。
多人协作
并不是一定要把本地分支往远程推送,那么,哪些分支需要推送,哪些不需要呢?
master分支是主分支,因此要时刻与远程同步;
dev分支是开发分支,团队所有成员都需要在上面工作,所以也需要与远程同步;
bug分支只用于在本地修复bug,就没必要推到远程了,除非老板要看看你每周到底修复了几个bug;
feature分支是否推到远程,取决于你是否和你的小伙伴合作在上面开发。
总之,就是在Git中,分支完全可以在本地自己藏着玩,是否推送,视你的心情而定!
多人协作的工作模式通常是这样:
1.首先,可以试图用git push origin 分支名推送自己的修改;
2.如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
3.如果合并有冲突,则解决冲突,并在本地提交;
4.没有冲突或者解决掉冲突后,再用git push origin 分支名推送就能成功!
如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream 分支名 origin/远程分支名。
小结
查看远程库信息,使用git remote -v;
本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用git push origin 分支名,如果推送失败,先用git pull抓取远程的新提交;
在本地创建和远程分支对应的分支,使用git checkout -b分支名origin/远程分支名,本地和远程分支的名称最好一致;
建立本地分支和远程分支的关联,使用git branch --set-upstream 分支名 origin/远程分支名;
从远程抓取分支,使用git pull,如果有冲突,要先处理冲突。
标签
命令git tag 用于新建一个标签,默认为最新版,也可以指定一个commit id;
git tag -a -m "blablabla..."可以指定标签信息;
git tag -s -m "blablabla..."可以用PGP签名标签;
命令git tag可以查看所有标签。
命令git show tagname查看标签信息
命令git push origin 可以推送一个本地标签;
命令git push origin --tags可以推送全部未推送过的本地标签;
命令git tag -d 可以删除一个本地标签;
命令git push origin :refs/tags/可以删除一个远程标签。
安装git服务器
1、安装SSH
sudo apt-get install openssh-serversudo service ssh start
2、安装Git
sudo apt-get install git
3、创建用户git
sudo adduser git
4、禁止git用户Shell登录
sudo vim /etc/passwd
git:x:1001:1001:,,,:/home/git:/bin/bash改成git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell
5、创建存放的仓库
sudo mkdir/home/git/repositories #最好使用repositories作为文件夹名称,这样可以简化后面的操作 sudo chown git:git /home/git/repositories sudo chmod 755 /home/git/repositories
6、创建子项目
cd /home/git/repositories
sudo git init --bare sample.git
作为服务器的仓库一定是裸仓库(裸库就是clone或者init的时候加了--bare选项),如果想看到文件的话在另外一个位置重新clone一个版本库就可以了。
7、修改子项目权限
sudo chown -R git:git sample.git
8、(各自电脑)在别的电脑上进行clone然后开始提交推送等操作
git clone git@IP:/home/git/repositories/sample.gittouch README
git add README
git commit -m 'first commit'
git remote add origin git@IP:/home/git/repositories/sample.git
git push -u origin master
9、(各自电脑)配置每个提交者的账号信息
git config --global user.name "你的注册用户名"
git config --global user.emall "你的注册邮箱"
10、(在Git服务器)配置免密码登录git账号
ssh-keygen各自主机生成ssh秘钥
到服务器/home/git/.ssh目录下,新建authorized_keys文件,并将id_rsa.pub里的内容复制进去
注意:新建后,需要更改authorized_keys文件的用户权限,不然文件可能无法生效,ssh公钥生效需满足至少下面两个条件:1 .ssh目录的权限必须是700;2 .ssh/authorized_keys文件权限必须是600
chmod 600 ~/.ssh/authorized_keys
我装的时候没设置也能用,如果不能用再试下。
其实不难发现这个操作就是SSH的免密码登录操作,参考:http://www.cnblogs.com/EasonJim/p/7569611.html
扩展
要方便管理公钥,用Gitosis;
要像SVN那样变态地控制权限,用Gitolite,或者gogs。
官方文档
https://www.git-scm.com/book/zh/v2/