Heim > Fragen und Antworten > Hauptteil
git 做单版本在线的项目是很成熟的,流程很清晰,每个issue创建一个branch,然后合并到master,打tag即可。
比如web项目,发布了1.0.0,然后修bug发布1.0.1、 1.0.2,新功能1.1.0、 1.2.0,改版大功能2.0.0 。只有一个版本在维护,一般不会出现 1.0.0 和 2.0.0 同时都在发布新版的情况。
git简单流程:http://rogerdudler.github.io/git-guide/index.zh.html
复杂点的流程:http://jiongks.name/blog/a-successful-git-branching-model/
但多版本并行发布的时候怎么办?
以Ubuntu系统为例,14.04 、 14.10 、 15.04 同时存在,14.10发布后,14.04也在持续的发布新版,比如14.04.1 、 14.04.2。
如果按照上面的git简单工作流程:
14.04在master里打tag发布了,下一个里程碑是14.10,很多人开发了很多分支,然后合并到master里,每天发布daily build版,看起来很美好。
突然,14.04有个紧急bug要修复,不可能等几个月等到14.10发布时带着一起修复,需要发布14.04.1那怎么办?从哪里checkout 14.04的代码?即使从tag里checkout下来了,修复完毕,合并到哪里?只能合并到master,但master是14.10,不能发布啊。
如果按照git复杂流程:
14.04在master里打tag发布了,下一个里程碑是14.10,很多人开发了很多分支,然后合并到develop分支里,每天发布daily build版。
突然,14.04有个紧急bug要修复,从master拉一个分支叫做hotfix-xxx,修复完毕,合并到master,打tag,发布14.04.1 。也合并到develop。
当14.10开发完毕,打算发布时,从develop拉一个分支叫做release-14.10,收尾完毕,把release-14.10合并到master,打个tag,发布了。也合并到develop,看起来很美好。
突然,14.04又有个紧急bug要修复,需要发布14.04.2怎么办?从哪里checkout 14.04.1的代码?即使从tag里checkout下来了,修复完毕,合并到哪里?只能合并到master,但master是14.10啊。
难道是每个版本一个项目? 比如 14.04 、14.10 、15.04 是3个项目?
这样感觉很奇怪,不优雅。请教大家有没有什么好办法。
为情所困2017-05-02 09:21:04
从tag:v14.04
拉一个分支叫branch:14.04.1-dev
,在里面进行开发,稳定以后打上tag:v14.04.1
就好,不用拘泥于“分支=>开发=>合并”,不需要合并的时候就不合并,一点问题都不会有,尤其是多版本同时维护的时候,cherry-pick取代merge是常态
不过git的master确实有点混淆,不同的项目的策略不一样,有的master是stable的含义,里面是稳定版本,新版本在分支里,有的反过来master是dev的含义,稳定版本在分支里。还有的master是release的含义,里面是“保持和线上部署一致的那份代码”。 所以我觉得可能直接不用master,用更明确的分支名称有可能是个更好的策略?
为情所困2017-05-02 09:21:04
我认为你描述的场景下,不同的版本在不同的分支下或者不同的项目下基本是一样的,因为不同分支之间基本不会合并了(分支叫什么名字可以不用太过在意)。那么在一个改动如果需要应用到不同版本时,我觉得可以考虑如下的方法:
当然,每种方法都有坑是毫无疑问的。
给我你的怀抱2017-05-02 09:21:04
你好,这种复杂的版本场景适合用 Gitflow,可以直接去看 Gitflow 了解一下。链接为:http://nvie.com/posts/a-successful-git-branching-model/