PHP gitflow 实战,使用 git-flow 自动化你的 git 工作流

介绍一下

git flow 分支模型相信大家或多或少都听过,先放张图镇楼:

1460000021034359

上面的图看不懂没关系(我也不懂==),今天讲的是根据这个分支模型开发的 git-flow 命令行工具。只需要记住几个简单的命令,就能在工作中慢慢理解和应用这个分支模型~

安装 git-flow

我们选择比较流行的 avh 版本 gitflow-avh

下面以 Mac OS X 为例,安装命令:

$ brew install git-flow-avh

初始化 Git 仓库

下面针对一个只有 README.md 的文件夹执行以下命令,有条件的小伙伴可以跟着操作一下,加深记忆。

$ git flow init

Initialized empty Git repository in /Users/savokiss/demos/gitflow/.git/

No branches exist yet. Base branches must be created now.

Branch name for production releases: [master]

Branch name for "next release" development: [develop]

How to name your supporting branch prefixes?

Feature branches? [feature/]

Bugfix branches? [bugfix/]

Release branches? [release/]

Hotfix branches? [hotfix/]

Support branches? [support/]

Version tag prefix? [] v

Hooks and filters directory? [/Users/savokiss/demos/gitflow/.git/hooks]

可以看到 git flow init 命令会要求你选择两个主分支,以及多个功能分支的前缀,我们都使用默认值,而版本号 Tag 前缀使用 v

需要说明的是,git-flow 其实只是一系列 git 命令的组合,init 命令除了会新建分支,不会做其他额外的操作。所以如果以后你不再使用 git-flow,也不需要做任何变更。

注意上面的 init 操作完成,会自动帮我们切到 develop 分支

Feature 功能分支

假设我们需要新建一个功能分支 auth 来做登录功能的开发。让我们先切到 master 分支:

$ git checkout master

然后开始新的功能分支,控制台输出如下:

$ git flow feature start auth

Switched to a new branch 'feature/auth'

Summary of actions:

- A new branch 'feature/auth' was created, based on 'develop'

- You are now on branch 'feature/auth'

Now, start committing on your feature. When done, use:

git flow feature finish auth

可以看到我们是在 master 分支上执行的命令,但是 feature/auth 分支却是基于 develop 切出的,因为根据上面的分支模型,所有的功能分支都应该从 develop 分支切出。这也就是 git-flow 的好处,你可以不用在意当前所在的分支,它会自动帮你保证没有切错分支~

接下来我们来修改一下 README.md,添加一句话 登录功能已经完成!,然后提交。

然后再执行完成命令,控制台输出如下:

$ git flow feature finish auth

Switched to branch 'develop'

Updating e69b22c..f7f48e2

Fast-forward

# gitflow | 0

README.md | 4 ++++

2 files changed, 4 insertions(+)

create mode 100644 # gitflow

create mode 100644 README.md

Deleted branch feature/auth (was f7f48e2).

Summary of actions:

- The feature branch 'feature/auth' was merged into 'develop'

- Feature branch 'feature/auth' has been locally deleted

- You are now on branch 'develop'

从输出可以看出:

feature/auth 分支被合并到了 develop 分支中。

feature/auth 分支被删除了

自动切换到了 develop 分支

而在 1 中 git-flow 内部使用如下命令 git merge --no-ff feature/auth 来进行合并,关于 --no-ff 参数,简单来说,可以更好地保留 feature 历史记录,感兴趣的小伙伴可以自行查阅相关资料哈

Release 版本发布

通常情况下,我们会使用基于 semver 的语义化版本规范来管理软件发布。

git-flow 也支持创建 release 分支。下面我们来发布一个 0.1.0 版本:

$ git flow release start 0.1.0

Switched to a new branch 'release/0.1.0'

Summary of actions:

- A new branch 'release/0.1.0' was created, based on 'develop'

- You are now on branch 'release/0.1.0'

Follow-up actions:

- Bump the version number now!

- Start committing last-minute fixes in preparing your release

- When done, run:

git flow release finish '0.1.0'

可以看出,该命令自动基于 develop 切出了 release/0.1.0 分支。

然后提示你在此分支上进行如下操作:

修改软件版本号

进行针对此版本的 bug 修复

在正常的开发流程中,提测后的 bug 修复阶段就可以在这个 release/0.1.0 分支上做,然后等测试通过后,就可以标记版本发布完成:

$ git flow release finish 0.1.0

Switched to branch 'master'

Switched to branch 'develop'

Already up to date!

Merge made by the 'recursive' strategy.

Deleted branch release/0.1.0 (was f7f48e2).

Summary of actions:

- Release branch 'release/0.1.0' has been merged into 'master'

- The release was tagged 'v0.1.0'

- Release tag 'v0.1.0' has been back-merged into 'develop'

- Release branch 'release/0.1.0' has been locally deleted

- You are now on branch 'develop'

可以看到,当你 finish 了一个 release,git-flow 内部执行了以下操作:

release/0.1.0 分支被合并到 master 和 develop

v0.1.0 标签被打在 master 上

release/0.1.0 分支被删除

当前切换到了 develop 分支

Hotfix 生产热修复

由于 master 分支一直反映了线上生产环境的状况,所以如果要进行生产热修复,就需要从 master 分支切出,下面假如我们线上的 banner 有一个 bug:

$ git flow hotfix start banner

Switched to a new branch 'hotfix/banner'

Summary of actions:

- A new branch 'hotfix/banner' was created, based on 'master'

- You are now on branch 'hotfix/banner'

Follow-up actions:

- Start committing your hot fixes

- Bump the version number now!

- When done, run:

git flow hotfix finish 'banner'

上面可以看出,从 master 切出了一个 hotfix/banner 分支,

接下来你可以在该分支进行生产 bug 修复的提交以及版本号的变更。

需要注意的是:hotfix 分支和 release 分支比较像,唯一的区别是 hotfix 分支是基于 master 切出的。

我们先修改一下 README.md 文件并提交,然后完成 bug 修复:

$ git flow hotfix finish banner

Switched to branch 'develop'

Deleted branch hotfix/banner (was c6da343).

Summary of actions:

- Hotfix branch 'hotfix/banner' has been merged into 'master'

- The hotfix was tagged 'vbanner'

- Hotfix tag 'vbanner' has been back-merged into 'develop'

- Hotfix branch 'hotfix/banner' has been locally deleted

- You are now on branch 'develop'

上面完成了:

hotfix/banner 分支被合并到 master 和 develop

这个热更新被自动打上标签 vbanner(由于我们前面设置标签前缀为 v)

hotfix/banner 分支被删除

目前切换到分支 develop

由于我没有关联远端 origin,所以这里只会提示本地分支被删除,如果关联后远端分支也会被删除。

完了

上面我们体验了 git-flow 的基本操作流程。为了方便演示,我是基于一个空项目操作的,实际上也可以针对一个开发了很久的 git 仓库来进行 git flow init,它会让你选择已经存在的分支作为 生产分支 和 开发分支 以及输入相应的前缀,其余不会做任何多余的操作。

另外 Sourcetree 是一个好用免费的 Git 图形化客户端,同时支持 Windows 和 Mac,并且内置了 git-flow 工具,感兴趣的小伙伴也可以尝试一下~

如果想了解更多,可以参见文末的链接,其中有个 cheatsheet 也可以快速熟悉 git flow 命令。

相信有了 git-flow 这个工具,在做分支管理的时候可以相对无痛一点~

参考链接

欢迎关注我的公众号:码力全开(codingonfire)

每周更新一篇原创或翻译文章~

1460000019604563

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值