资讯专栏INFORMATION COLUMN

Git 工作流

Tecode / 2017人阅读

摘要:工作流如下图所示现在让我们来看一个最简单的分支管理的例子。切换到之前实现新需求的分支,将修补分支合并进来,然后继续工作。这里我们参考一文来学习工作流。分支产品发布测试分支。

Git 工作流如下图所示:

git-flow.png

现在让我们来看一个最简单的分支管理的例子。

  1. 开发某个网站,为实现某个新的需求,创建一个分支并在这个分支上开展工作。
  2. 此时,你突然接到一个电话说有个 Bug 需要紧急修补。
  3. 返回到原先已经发布到生产服务器上的分支,为这次紧急修补建立一个新分支,并在其中修复问题。
  4. 通过测试后,回到生产服务器所在的分支,将修补分支合并进来,然后再推送到生产服务器上。
  5. 切换到之前实现新需求的分支,将修补分支合并进来,然后继续工作。

这里我们参考 A successful Git branching model 一文来学习 Git 工作流。

主分支

主分支包括 master 分支和 develop 分支。

  • master 分支
  • develop 分支

master 分支用来发布,HEAD 就是当前线上的运行代码。develop 分支就是我们的日常开发。使用这两个分支就具有了最简单的开发模式:develop 分支用来开发功能,开发完成并且测试没有问题则将 develop 分支的代码合并到 master 分支并发布。

main-branches.png

辅助分支

主要介绍的辅助分支如下:

  • feature 分支
  • release 分支
  • hotfix 分支

通过这些分支,我们可以做到:团队成员之间并行开发,feature track 更加容易,开发和发布并行以及线上问题修复。辅助分支与主分支的不同点:辅助分支是有限的生命期,他们最终会被移除。

Feature 分支

feature 分支用来开发具体的功能,一般 fork 自 develop 分支,最终可能会合并到 develop 分支。比如我们要在下一个版本增加功能 1、功能 2、功能 3。那么我们就可以起三个 feature 分支:feature1feature2 feature3。(feature 分支命名最好能够自解释,这并不是一种好的命名。)随着我们开发,功能 1 和功能 2 都被完成了,而功能 3 因为某些原因完成不了,那么最终 feature1feature2 分支将被合并到 develop 分支,而 feature3 分支将被干掉。

feature-branches.png

建立 feature 分支并切换到 feature 分支

从 develop 分支建立 feature 分支并切换到 feature 分支。

$ git checkout -b myfeature develop
Switched to a new branch "myfeature"

合并 feature 分支到 develop

$ 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查看。)

merge-without-ff.png
)

看了上面的图,那么使用非fast-forward模式来 merge 的好处就不言而喻了:我们知道哪些 commit 是某些 feature 相关的。虽然 git merge 的时候会自动判断是否使用fast-farward模式,但是有时候为了更明确,我们还是要加参数--no-ff或者--ff

Release 分支

release 分支在我看来是 pre-masterrelease 分支从 develop 分支 fork 出来,最终会合并到 develop 分支和 master 分支。合并到 master 分支上就是可以发布的代码了。有人可能会问那为什么合并回 develop 分支呢?很简单,有了 release 分支,那么相关的代码修复就只会在 release 分支上改动了,最后必然要合并到 develop 分支。下面细说。

我们最初所有的开发工作都在 develop 分支上,当我们这一期的功能开发完毕的时候,我们基于 develop 分支开一个新的 release 分支。这个时候我们就可以对 release 分支做统一的测试了,另外做一些发布准备工作:比如版本号之类的。

如果测试工作或者发布准备工作和具体的开发工作由不同人来做,比如国内的 RDQA,这个 RD 就可以继续基于 develop 分支继续开发了。再或者说公司对于发布有严格的时间控制,开发工作提前并且完美的完成了,这个时候我们就可以在 develop 分支上继续我们下一期的开发了。同时如果测试有问题的话,我们将直接在 release 分支上修改,然后将修改合并到 develop 分支上。

待所有的测试和准备工作做完之后,我们就可以将 release 分支合并到 master 分支上,并进行发布了。

一些相关命令如下。

新建 release 分支

$ 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(-)

release 分支合并到 master 分支

$ 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

release 分支合并到 develop 分支

$ git checkout develop
Switched to branch develop
$ git merge --no-ff release-1.2
Merge made by recursive.
(Summary of changes)

删除 release 分支

$ git branch -d release-1.2
Deleted branch release-1.2 (was ff452fe).

Hotfix 分支

顾名思义,hotfix 分支用来修复线上 bug。当线上代码出现 bug 时,我们基于 master 分支开一个 hotfix 分支,修复 bug 之后再将 hotfix 分支合并到 master 分支并进行发布,同时 develop 分支作为最新最全的代码分支,hotfix 分支也需要合并到 develop 分支上去。仔细想一想,其实 hotfix 分支和 release 分支功能类似。hotfix 的好处是不打断 develop 分支正常进行,同时对于现实代码的修复貌似也没有更好的方法了.

hotfix-branches.png

一些相关的命令。

新建 hotfix 分支

$ 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(-)

Fix bug

$ git commit -m "Fixed severe production problem"
[hotfix-1.2.1 abbe5d6] Fixed severe production problem
5 files changed, 32 insertions(+), 17 deletions(-)

hotfix 合并到 master

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

hotfix 合并到 develop 分支

$ git checkout develop
Switched to branch develop
$ git merge --no-ff hotfix-1.2.1
Merge made by recursive.
(Summary of changes)

删除 hotfix 分支

$ 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的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。...

    付伦 评论0 收藏0
  • Git常用命令小结

    摘要:使用此命令能看到那些修改被暂存到了哪些没有哪些文件没有被到。需要说明一点,是本地的,不会通过命令上传到上。查看现有的所有储藏,此命令显然暗示了可以多次保存工作进度,并用在恢复时候选择。 Git 版本库原理 Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。...

    Airmusic 评论0 收藏0
  • Git 基本命令,你都学废了吗

    摘要:掌握了命令行,使用图形化工具如探囊取物。管理的文件状态已修改已暂存已提交。由于我们使用了命令,但并未创建新的分支,所以创建了一个匿名分支。省略远程分支名表示将本地分支推送到与之存在追踪关系的远程分支通常同名。概述此篇博文意在让新手快速上手 Git,满足工作中的基本需求,而非梳理细节。后续会再开一个系列,来探讨 Git 细节问题。一、Git 的安装这部分网站上资料非常多,根据自己的系统版本查找...

    Tecode 评论0 收藏0
  • Git常用命令

    摘要:工作区状态被改变,用这查看修改内容。添加文件到仓库,分两步使用命令,注意,可反复多次使用,添加多个文件。使用命令,完成。版本回退命令显示从最近到最远的提交日志。要重返未来,用查看命令历史,以便确定要回到未来哪个版本。 创建版本库mkdir learngit 创建learngit目录cd learngit 进入文件夹里pwd 查看目录路径git init 初始化仓库git add re....

    宠来也 评论0 收藏0
  • Git 系列】基础知识全集

    摘要:没有一个全局的版本号,而有目前为止这是跟相比缺少的最大的一个特征。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。合并冲突多人对同一文件的工作副本进行更改,并将这些更改提交到仓库。Git 是一种分布式版本控制系统,它可以不受网络连接的限制,加上其它众多优点,目前已经成为程序开发人员做项目版本管理时的首选,非开发人员也可以用 Git 来做自己的文档版本管理工具。 ...

    ASCH 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<