Git+GitHub,构建自己的开源仓库之Git分支

封面--来源网络

简介

最近公司里还是没什么事做,虽然工资还是在正常发,但是还是要有忧患意识,毕竟,生于忧患,死于安乐。所以,最近一段时间都处于学习状态,越学习越发现要学的东西太多,越学习越发现自己懂得少。言归正传,今天记录一下Git分支的相关知识。


远离舒适区,常驻学习区

Git分支命令

命令 描述 示例
git branch <branch-name> 创建分支 git branch dev
git branch 查看本地分支 git branch
git branch -r 查看远程分支 git branch -r
git checkout <branch-name> 切换分支 git checkout develop
git checkout -b <branch-name> 创建并切换到分支 git checkout -b release
git branch -d <branch-name> 删除分支 git branch -d bug-fix-109
git branch -D <branch-name> 强制删除分支 git branch -D bug-fix-110
git merge <branch-name> 合并分支到当前分支 git merge develop
git log --graph --pretty=oneline --abbrev-commit 查看分支合并记录 git log --graph --pretty=oneline --abbrev-commit

上表中列出了git分支操作的基本命令,还有一些高级用法,以及一些配合使用的其他命令,如git log --graph --pretty=oneline --abbrev-commit,下面就逐条来解读这些命令。

我们在操作这些命令的时候,都要注意一些,要明白自己当前在哪个分支操作,要对哪个分支产生效果。我们在创建完一个本地仓库后,会自动创建一个主分支,即master分支,在未进行任何分支操作之前,我们都是在master主分支上操作的。

创建分支

创建一个develop分支:

git branch develop
  • 为什么要创建分支?
    不影响主线分支的情况下开展工作,协同团队其他成员共同开发。

  • SVN等其他版本控制系统也有分支功能,为什么都没怎么用过?
    创建/切换/删除分支的成本太高,太慢,没法愉快的玩耍,于是就成了摆设,而Git则不同,创建切换分支都是秒级完成,根本感受不到。因此Git推荐开发者多多的使用分支功能。

    创建完一个分支后,Git就会生成一个指针develop,指向的是当前commit节点的提交,另一个分支master也有一个指针master指向当前commit节点的提交。当我们在develop分支上提交新的内容后,develop指针就会指向这个提交,而master指针依然指向原来的提交。

查看本地分支

git branch

这条命令会列出本地已创建的分支,并且会在分支名字前面用星号*标记当前所在的分支:

 chengshengyang@csy-pc MINGW64 ~/test (master)
$ git branch
  develop
* master

查看远程分支

git branch -r

列举远程仓库的分支

$ git branch -r
  origin/HEAD -> origin/master
  origin/master

可以看到远程仓库只有一个分支,本地的develop还没有push到远程仓库,指针HEAD指向的是master分支。

切换分支

git checkout develop

切换到develop分支

$ git checkout develop
Switched to branch 'develop'

切换分支其实是Git将HEAD指针做了修改,指向了develop,所以这个过程很快。

创建并切换分支

其实就是创建切换二合一的命令,可以快速的切换到新的分支

 git checkout -b release

chengshengyang@csy-pc MINGW64 ~/test (develop)
$ git checkout -b release
Switched to a new branch 'release'
chengshengyang@csy-pc MINGW64 ~/test (release)

直接从develop分支切换到了新建的release分支了,一步到位。

合并分支

git merge develop

此时,我们在develop上的工作完成了,需要合并到master分支,准备发布用。先切换到master分支:

git checkout master

开始合并:

git merge develop

这之前,我们在develop分支对b.txt文件做了修改:

$ cat b.txt
00000000000000000000000000
111111111111111111111111111
2222222222222222323333333333
chengshengyang@csy-pc MINGW64 ~/test (develop)
$ vim b.txt

chengshengyang@csy-pc MINGW64 ~/test (develop)
$ cat b.txt
00000000000000000000000000
111111111111111111111111111
2222222222222222323333333333
git create branch is fast.

提交修改:

chengshengyang@csy-pc MINGW64 ~/test (develop)
$ git add b.txt

chengshengyang@csy-pc MINGW64 ~/test (develop)
$ git commit -m "modify b.txt"
[develop eb926ac] modify b.txt
1 file changed, 2 insertions(+), 1 deletion(-)

切换到master分支后,同样,也修改一下b.txt文件的最后一行:

chengshengyang@csy-pc MINGW64 ~/test (master)
$ cat b.txt
00000000000000000000000000
111111111111111111111111111
2222222222222222323333333333
chengshengyang@csy-pc MINGW64 ~/test (master)
$ vim b.txt

chengshengyang@csy-pc MINGW64 ~/test (master)
$ cat b.txt
00000000000000000000000000
111111111111111111111111111
2222222222222222323333333333
git merge branch is fast.

chengshengyang@csy-pc MINGW64 ~/test (master)
$ git add b.txt

chengshengyang@csy-pc MINGW64 ~/test (master)
$ git commit -m "modify b.txt master"
[master 9e2050b] modify b.txt master
1 file changed, 2 insertions(+), 1 deletion(-)

现在master分支和develop分支都修改了b.txt的同一个位置,现在合并develop分支到master分支肯定会冲突:

chengshengyang@csy-pc MINGW64 ~/test (master)
$ git merge develop
Auto-merging b.txt
CONFLICT (content): Merge conflict in b.txt
Automatic merge failed; fix conflicts and then commit the result.

现在看看b.txt被合并成什么样子了:

$ cat b.txt
00000000000000000000000000
111111111111111111111111111
2222222222222222323333333333
<<<<<<< HEAD
git merge branch is fast.
=======
git create branch is fast.
>>>>>>> develop

跟其他版本控制系统类似,会用<<<<<<<<、========、>>>>>>>>来划分冲突的内容。因为Git不知道master分支和develop分支哪个提交的内容是正确的,需要程序员手动修改后提交,注意我们此时所处的分支状态是这样的:

chengshengyang@csy-pc MINGW64 ~/test (master|MERGING)

(master|MERGING)状态,说明在主分支master进行合并的状态,合并未完成。解决冲突后提交:

$ cat b.txt
00000000000000000000000000
111111111111111111111111111
2222222222222222323333333333D
git merge branch is fast.
git create branch is also fast.

chengshengyang@csy-pc MINGW64 ~/test (master|MERGING)
$ git commit -m "merge develop"
U       b.txt
error: commit is not possible because you have unmerged files.
hint: Fix them up in the work tree, and then use 'git add/rm <file>'
hint: as appropriate to mark resolution and make a commit.
fatal: Exiting because of an unresolved conflict.

chengshengyang@csy-pc MINGW64 ~/test (master|MERGING)
$ git add b.txt

chengshengyang@csy-pc MINGW64 ~/test (master|MERGING)
$ git status
On branch master
Your branch is ahead of 'origin/master' by 1 commit.
  (use "git push" to publish your local commits)
All conflicts fixed but you are still merging.
  (use "git commit" to conclude merge)

Changes to be committed:

    modified:   b.txt


chengshengyang@csy-pc MINGW64 ~/test (master|MERGING)
$ git commit -m "merge develop-fix conflict"
[master abffc90] merge develop-fix conflict

这里我犯了个错,解决冲突后没有add就直接commit,于是有了上面的一个提交失败提示。
冲突解决后,文件需要执行add操作后才能commit,如果不清楚可以先用git status查看状态

查看分支合并记录

git log --graph --pretty=oneline --abbrev-commit

这条命令是说用线条的形式显示分支的合并记录:

chengshengyang@csy-pc MINGW64 ~/test (master)
$ git log --graph --pretty=oneline --abbrev-commit
*   abffc90 merge develop-fix conflict
|\
| * eb926ac modify b.txt
* | 9e2050b modify b.txt master
|/
* 7bbd5fc add 19.png for jianshu.io

这条命令比较长,不好记,可以给它设置一个简单的别名,但是这里暂时不说如何设置,还是多写写这些命令,等记住了,熟练了再设置个别名,提高效率顺便装装逼啥的。

上面的合并方式是普通模式,已经很快了,但是有种模式叫“快进模式”,即Fast Forward,更快。一般合并没有冲突的时候,Git都会使用Fast Forward模式快速合并,这种合并模式也是修改指针,所以快。但是,使用Fast Forward模式合并后,如果删除合并的分支,使用上面的命令git log --graph --pretty=oneline --abbrev-commit就看不到分支的信息了,如果要避免这种情况,要使用下面的命令来合并:

git merge --no-ff -m "commit description" fix-bg-001

参数"--no-ff"指定合并不使用快进模式,使用普通模式。

删除分支

如果你现在在一个bug分支上解决一个bug,然后去develop分支、master分支合并成功了,这个分支也就没什么用了,可以删掉了:

chengshengyang@csy-pc MINGW64 ~/test (master)
$ git branch -d fix-bug-001
Deleted branch fix-bug-001 (was 0309fed).

如果分支内容还没有合并就要删除,会提示错误信息:

$ git branch -d test
error: The branch 'test' is not fully merged.
If you are sure you want to delete it, run 'git branch -D test'.

而且提示了可以使用

git branch -D test

来强制删除:

$ git branch -D test
Deleted branch test (was 92b398f).

以上就是git分支的一些基本命令的解读了,学会了这些基本操作,才能更好的理解分支管理的策略。

分支管理策略

其实说到分支管理策略,我本人也没有什么值得借鉴的经验,所以,这里就做了点功课,看看别人是怎么做分支管理的。

一般企业中开发一个项目的分支策略:

  • 主分支 master
    Git主分支的名字,默认叫做master。它是自动建立的,版本库初始化以后,默认就是在主分支在进行开发。所有提供给用户使用的正式版本,都在这个主分支上发布。
    master分支要时刻与远程同步,一般我们发布最新版本就用master分支。
  • 开发分支 develop
    主分支只用来分布重大版本,日常开发应该在另一条分支上完成。开发用的分支叫做Develop。这个分支可以用来生成代码的最新代码版本。如果想正式对外发布,就在Master分支上,对Develop分支进行"合并"(merge)。
    团队中所有人都在这个分支上开发,所以也需要与远程同步。
  • 功能分支 feature
    功能分支,它是为了开发某种特定功能,从Develop分支上面分出来的。开发完成后,要再并入Develop。功能分支的名字,可以采用feature-*的形式命名。
    该分支是否需要推送到远程,要看是不是有几个人合作开发新功能,如果你是一个开发,就没有必要了。
  • 预发布分支 release
    预发布分支,它是指发布正式版本之前(即合并到Master分支之前),我们可能需要有一个预发布的版本进行测试。预发布分支是从Develop分支上面 分出来的,预发布结束以后,必须合并进Develop和Master分支。它的命名,可以采用release-*的形式。
    建议该分支推送到远程仓库。
  • bug 分支 fixbug
    bug分支,软件正式发布以后,难免会出现bug。这时就需要创建一个分支,进行bug修补。修补bug分支是从Master分支上面分出来的。修补结束以后,再合并进Master和Develop分支。它的命名,可以采用fixbug-*的形式。
    bug分支一般只在本地使用来修复bug,一般不需推送远程仓库中,修复合并后删除分支。
  • 其它分支 other
    根据具体情况具体对待。

以上是根据网上摘取的关于分支管理策略的一些内容,不一定适合每个人,仅供参考。

总结

对于分支的操作就写这么多,如果您还有什么想知道的,就自己去网上找找相关资料,留言给我也可。如果觉得我的文章对你有用,欢迎点赞。有不足之处欢迎留言指出,谢谢。
看完本文的你或许对前两篇内容也感兴趣
Git+GitHub,构建自己的开源仓库之Git命令
Git+GitHub,构建自己的开源仓库之初识Git

最后,分享一首歌曲:
Girl From Heavens

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容

  • 1.git的安装 1.1 在Windows上安装Git msysgit是Windows版的Git,从https:/...
    落魂灬阅读 12,657评论 4 54
  • 秋天于我,是辽阔的,也是感伤的。我经常会记起那个秋天,飘扬而去的是一缕缕无可把握的悲哀。 四年级的我,还是一个“疯...
  • 美索不达米亚平原在中东两河流域,又名两河平原。是一片位于底格里斯河及幼发拉底河之间的冲积平原,现今的伊拉克境内,那...
    艾米乐乐阅读 1,080评论 0 0
  • 生活中每一桩糟糕的事,几乎都是时机不当的结果,每件好事,都是时机恰到好处的结果。——《岛上书店》 这是一座岛,来来...
    盔甲骑士阅读 326评论 1 1
  • 哈佛大学---世界一流学府,其中走出不少杰出 和成功人物,如我像神一般存在,当看到(哈佛凌晨四点半)一书,并想来看...
    娇之语阅读 631评论 0 0