git总结

说明:本次总结来自廖雪峰的官方网站,仅供学习如有侵权请联系管理员删除。

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中。


git总结_第1张图片

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总结_第2张图片

解决合并冲突

删除带<<<<<<<,=======,>>>>>>>标识

或者、先把自己的文件还原然后在合并,在添加自己修改的代码。

用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总结_第3张图片

小结

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/

你可能感兴趣的:(git总结)