A successful Git branching model的理解

简介: 文章末尾的这张图,很多人都看过,我在好多年前就看过,一直没有理解,觉得要同时维护这么多的分支,基本上就不用做事了,所以在团队中,一直都是使用master分支一撸到底,还好这些年没有出大问题。 今天临下班的时候,有点闲时间,再次翻到这张图,仔细看了20来分钟,恍然大悟,原来这个模型简单又好用,以前之所以觉得复杂,一方面是我看书不够细心,另外一方面,也是网上的绝大部分文章,根本就没有讲清楚这张图的重点。

文章末尾的这张图,很多人都看过,我在好多年前就看过,一直没有理解,觉得要同时维护这么多的分支,基本上就不用做事了,所以在团队中,一直都是使用master分支一撸到底,还好这些年没有出大问题。

今天临下班的时候,有点闲时间,再次翻到这张图,仔细看了20来分钟,恍然大悟,原来这个模型简单又好用,以前之所以觉得复杂,一方面是我看书不够细心,另外一方面,也是网上的绝大部分文章,根本就没有讲清楚这张图的重点。

这张图,只要注意竖线的颜色,黑色是分支存在的生命阶段,浅灰色是相反。所以,日常开发,在git remote server上长期存在的分支,就两个“master”和“develop”。

master分支:作为稳定的产品发布后的分支,平时改动很少,tag也只打在这个分支上。

develop分支:就是团队日常开发使用的分支,代码提交频繁,基本上其它的分支,都是从develop分支上创建的,并且其它分支上的修改,都要合并到develop分支上。

至于其它的分支,都是短期存在的临时分支,从右到左把他们的功用听我简单一说就明白了。

hotfixes分支:这个分支用于已经正式发布的生产版本(也就是master上打了tag)出现bug的时候,从master分支的某个tag(一般是最新的一个,除非同时维护多个发布版本)里,branch一个分支,一般起名hotfixNN(NN代表两位数字),用于修复bug。当bug修复后,就合并到master和dev分支,并且在master分支上打上新的tag,hotfixes生命周期结束,就可以删除了。这个分支存在时间较短,一般情况下不推送到remote。

release分支:当开发到一定时间后,准备发布新版本,从develop分支branch一个新的分支,取名release,或者是1.0这样的版本号,接下来这个分支只进行bug修复,不再从别的分支合并新特性,并且每修复一个bug,就要合并到develop分支。等到bug修复得差不多了,可以发布新版了,就把release分支合并到master和develop,并在master分支上打上tag,release分支生命周期结束,删除。这个分支一般会存在一段时间,也需要团队一起修复多个bug,所以推送到remote。

feature分支:这分支是很频繁的从develop分支上branch出来,完成开发和本地测试后,又频繁的合并到develop。这类分支不论存在时间长短,一般只存在开发人员的本地,不推送到remote。在某些情况下,当需求变更,某些特性不需要了时,分支直接就放弃删除了。

以后的团队协作,就用这个模型了。
git_flow

目录
相关文章
|
开发工具 git
分享一个学习Git的网站 Learn Git Branching
分享一个学习Git命令的网站,循序渐进按课程闯关编写的,做的非常棒,界面还很可爱! 建议手动输入git命令,可以在动画中很明白地看到指针和路径是如何变化的,很有趣。
1451 0
|
4月前
|
存储 开发工具 git
|
27天前
|
缓存 Java Shell
[Git]入门及其常用命令
本文介绍了 Git 的基本概念和常用命令,包括配置、分支管理、日志查看、版本回退等。特别讲解了如何部分拉取代码、暂存代码、删除日志等特殊需求的操作。通过实例和图解,帮助读者更好地理解和使用 Git。文章强调了 Git 的细节和注意事项,适合初学者和有一定基础的开发者参考。
45 1
[Git]入门及其常用命令
|
4月前
|
开发工具 git
【GIT 第二篇章】GIT常用命令
Git常用命令涵盖初始化、状态管理、提交、分支处理、远程操作等关键流程。`git init`启动本地仓库,`git clone`下载远程仓库。通过`git status`和`git diff`检查工作状态与差异。利用`git add`暂存文件,`git commit`保存更改。借助`git branch`、`git checkout`、`git merge`和`git rebase`管理分支。使用`git fetch`、`git pull`和`git push`同步远程仓库。通过`git reset`、`git revert`和`git checkout`实现版本回退。
72 0
|
2月前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
120 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
|
1月前
|
开发工具 git 开发者
|
1月前
|
开发工具 git 开发者
提升Git效率:掌握这5个高级命令
【10月更文挑战第17天】
45 0
|
3月前
|
存储 Linux 开发工具
掌握 Git 命令:每个开发者的必备技能
无论团队项目还是个人开发,掌握 Git 命令都是必备技能。本文介绍 Git 的基本概念与命令,如初始化仓库 (`git init`)、添加文件 (`git add`)、提交更改 (`git commit`)、检出分支 (`git checkout`)、合并分支 (`git merge`) 等,还分享了高级技巧如查看差异 (`git diff`)、撤销提交 (`git revert`)、修复合并冲突 (`git mergetool`) 和使用别名简化命令 (`git config --global alias.ci commit`)。
|
3月前
|
机器学习/深度学习 Shell 开发工具
Python使用管道执行git命令报错|4-7
Python使用管道执行git命令报错|4-7
|
3月前
|
存储 Linux 开发工具
Git基础命令,分支,标签的使用【快速入门Git】
本文详细介绍了Git版本控制系统的基础概念和常用命令,包括工作区、暂存区和版本库的区别,文件状态的变化,以及如何进行文件的添加、提交、查看状态、重命名、删除、查看提交历史、远程仓库操作和分支管理,还涉及了Git标签的创建和删除,旨在帮助读者快速入门Git。
Git基础命令,分支,标签的使用【快速入门Git】