摘要:工作流如下图所示现在让我们来看一个最简单的分支管理的例子。切换到之前实现新需求的分支,将修补分支合并进来,然后继续工作。这里我们参考一文来学习工作流。分支产品发布测试分支。
Git 工作流如下图所示:
现在让我们来看一个最简单的分支管理的例子。
Bug
需要紧急修补。这里我们参考 A successful Git branching model 一文来学习 Git 工作流。
主分支包括 master
分支和 develop
分支。
master
分支develop
分支master
分支用来发布,HEAD
就是当前线上的运行代码。develop
分支就是我们的日常开发。使用这两个分支就具有了最简单的开发模式:develop
分支用来开发功能,开发完成并且测试没有问题则将 develop
分支的代码合并到 master
分支并发布。
主要介绍的辅助分支如下:
feature
分支release
分支hotfix
分支通过这些分支,我们可以做到:团队成员之间并行开发,feature track
更加容易,开发和发布并行以及线上问题修复。辅助分支与主分支的不同点:辅助分支是有限的生命期,他们最终会被移除。
feature
分支用来开发具体的功能,一般 fork 自 develop
分支,最终可能会合并到 develop
分支。比如我们要在下一个版本增加功能 1、功能 2、功能 3。那么我们就可以起三个 feature
分支:feature1
、 feature2
和 feature3
。(feature
分支命名最好能够自解释,这并不是一种好的命名。)随着我们开发,功能 1 和功能 2 都被完成了,而功能 3 因为某些原因完成不了,那么最终 feature1
和 feature2
分支将被合并到 develop
分支,而 feature3
分支将被干掉。
从 develop 分支建立 feature 分支并切换到 feature 分支。
$ git checkout -b myfeature develop
Switched to a new branch "myfeature"
$ git checkout develop
Switched to branch develop
$ git merge --no-ff myfeature
Updating ea1b82a..05e9557
(Summary of changes)
$ git branch -d myfeature
Deleted branch myfeature
$ git push origin develop
上面我们 merge 分支的时候使用了参数 --no-ff
,ff 是fast-forward
的意思,--no-ff
就是禁用fast-forward
。关于这两种模式的区别如下图。(可以使用 sourceTree
或者命令git log --graph
查看。)
)
看了上面的图,那么使用非fast-forward
模式来 merge
的好处就不言而喻了:我们知道哪些 commit
是某些 feature
相关的。虽然 git merge
的时候会自动判断是否使用fast-farward
模式,但是有时候为了更明确,我们还是要加参数--no-ff
或者--ff
。
release
分支在我看来是 pre-master
。release
分支从 develop
分支 fork
出来,最终会合并到 develop
分支和 master
分支。合并到 master
分支上就是可以发布的代码了。有人可能会问那为什么合并回 develop
分支呢?很简单,有了 release
分支,那么相关的代码修复就只会在 release
分支上改动了,最后必然要合并到 develop
分支。下面细说。
我们最初所有的开发工作都在 develop
分支上,当我们这一期的功能开发完毕的时候,我们基于 develop
分支开一个新的 release
分支。这个时候我们就可以对 release
分支做统一的测试了,另外做一些发布准备工作:比如版本号之类的。
如果测试工作或者发布准备工作和具体的开发工作由不同人来做,比如国内的 RD
和 QA
,这个 RD
就可以继续基于 develop
分支继续开发了。再或者说公司对于发布有严格的时间控制,开发工作提前并且完美的完成了,这个时候我们就可以在 develop
分支上继续我们下一期的开发了。同时如果测试有问题的话,我们将直接在 release
分支上修改,然后将修改合并到 develop
分支上。
待所有的测试和准备工作做完之后,我们就可以将 release
分支合并到 master
分支上,并进行发布了。
一些相关命令如下。
$ git checkout -b release-1.2 develop
Switched to a new branch "release-1.2"
$ ./bump-version.sh 1.2
File modified successfully, version bumped to 1.2.
$ git commit -a -m "Bumped version number to 1.2"
[release-1.2 74d9424] Bumped version number to 1.2
1 files changed, 1 insertions(+), 1 deletions(-)
$ git checkout master
Switched to branch master
$ git merge --no-ff release-1.2
Merge made by recursive.
(Summary of changes)
$ git tag -a 1.2
$ git checkout develop
Switched to branch develop
$ git merge --no-ff release-1.2
Merge made by recursive.
(Summary of changes)
$ git branch -d release-1.2
Deleted branch release-1.2 (was ff452fe).
顾名思义,hotfix
分支用来修复线上 bug
。当线上代码出现 bug
时,我们基于 master
分支开一个 hotfix
分支,修复 bug 之后再将 hotfix
分支合并到 master
分支并进行发布,同时 develop
分支作为最新最全的代码分支,hotfix
分支也需要合并到 develop
分支上去。仔细想一想,其实 hotfix
分支和 release
分支功能类似。hotfix
的好处是不打断 develop
分支正常进行,同时对于现实代码的修复貌似也没有更好的方法了.
一些相关的命令。
$ git checkout -b hotfix-1.2.1 master
Switched to a new branch "hotfix-1.2.1"
$ ./bump-version.sh 1.2.1
Files modified successfully, version bumped to 1.2.1.
$ git commit -a -m "Bumped version number to 1.2.1"
[hotfix-1.2.1 41e61bb] Bumped version number to 1.2.1
1 files changed, 1 insertions(+), 1 deletions(-)
$ git commit -m "Fixed severe production problem"
[hotfix-1.2.1 abbe5d6] Fixed severe production problem
5 files changed, 32 insertions(+), 17 deletions(-)
Fix bug 之后,hotfix
合并到 master
$ git checkout master
Switched to branch master
$ git merge --no-ff hotfix-1.2.1
Merge made by recursive.
(Summary of changes)
$ git tag -a 1.2.1
$ git checkout develop
Switched to branch develop
$ git merge --no-ff hotfix-1.2.1
Merge made by recursive.
(Summary of changes)
$ git branch -d hotfix-1.2.1
Deleted branch hotfix-1.2.1 (was abbe5d6).
master
分支:主分支,主要存放已经发布到生产服务器上的代码。develop
分支:日常开发分支,该分支从 master
分支拉取,主要存放着在实现新的产品需求时开发的代码。feature
分支:日常开发特性分支。一般从 develop
分支拉取,主要存放着在实现新产品需求具体功能时开发的代码。具体功能开发完成之后将合并到 develop
分支。release
分支:产品发布测试分支。主要存放着从 develop
分支合并过来的代码。 develop
分支的代码在新的产品需求全部实现后会合并到 release
分支进行测试,测试没有问题后(到了发布日期)将会合并到 master
分支并发布。测试有问题将会在 release
分支修改,修改测试没问题后将会合并到 master
分支和 develop
分支。hotfix
分支:线上 bug 修复分支。主要存放这在紧急修补中为修复问题开发的代码,在测试没有问题后将会合并到 master
分支和 develop
分支。文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/125991.html
摘要:掌握了命令行,使用图形化工具如探囊取物。管理的文件状态已修改已暂存已提交。由于我们使用了命令,但并未创建新的分支,所以创建了一个匿名分支。省略远程分支名表示将本地分支推送到与之存在追踪关系的远程分支通常同名。概述此篇博文意在让新手快速上手 Git,满足工作中的基本需求,而非梳理细节。后续会再开一个系列,来探讨 Git 细节问题。一、Git 的安装这部分网站上资料非常多,根据自己的系统版本查找...
摘要:没有一个全局的版本号,而有目前为止这是跟相比缺少的最大的一个特征。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。合并冲突多人对同一文件的工作副本进行更改,并将这些更改提交到仓库。Git 是一种分布式版本控制系统,它可以不受网络连接的限制,加上其它众多优点,目前已经成为程序开发人员做项目版本管理时的首选,非开发人员也可以用 Git 来做自己的文档版本管理工具。 ...
阅读 3538·2023-04-25 20:09
阅读 3738·2022-06-28 19:00
阅读 3059·2022-06-28 19:00
阅读 3081·2022-06-28 19:00
阅读 3173·2022-06-28 19:00
阅读 2879·2022-06-28 19:00
阅读 3045·2022-06-28 19:00
阅读 2637·2022-06-28 19:00