【开源项目】保姆指导讲解优质项目分支管理

简介: 学委最近又开发了一个项目,后面会说。

这次学委讲讲开源项目的分支管理,帮助读者了解开源项目是怎么管理代码的。


多数开源项目都是main(以前是master/trunk)分支管理代码的。


开发版本或者中间修订版本走feature 分支发布,然后再定期合并到master 分支。


分支管理是什么

分支管理,简单理解,就是多条生产线管理,比如一款手机的多个版本的生产。


比如某个手机的三条生产线:


现售的Mate30手机,在装订生产。

同时还有Mate20旧版本还有部分销售订单还在继续装订。

新版本Mate40还在研发


这样就好理解,我们的项目代码就是制作手机的输入,通过管理多个分支,让不同产品线团队做到最大程度的独立开发,发布不同款式产品。


下面介绍一下著名开源项目和我们做开源项目应该怎么进行分支管理的


第一种 基于主干分支管理(Trunk Based)比如LINUX内核

我们打开Linux内核的主线repo,看到如下的分支,只有master主干分支。


image.png

非常简单,也比较典型的主干为中心的分支管理。


因为linux内核主线只有一个,新的特性代码会被不断提交到主线,新内核也没有必要支持向后移植。

如果需要得用指定的tag来检出特定版本分支,进行修订发行。


就像下图一样,以trunk分支为中心,每一个弯都是一个PR(Pull Request),合并到trunk分支。


image.png

学委补充一下PR,PR代表每次有效开发工作的提交与合并。


主干分支管理的好坏:


好处:简化管理,所有特性只要审核通过马上合并到主干分支。这样随时可以发布,也避免了出现大规模集成的风险。


缺点:一个个单一的提交造成问题不大,不过当出现颠覆式的提交或者多个提交,这些提交造成的问题会一直影响主干分支,也影响到每次发布,直到问题解决。


小伙伴可能有疑问了,那么稳定发行版本,如何进行打补丁(比如遇到bug或者安全漏洞需要提交修改)


稳定版本仓库:https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/


linux还有一个独立的stable 仓库,它基于主线分支的一次镜像(或者定期同步,主要是发行大版本的时候)。


确定了发行的主版本后,做一个分支发布为stable仓库,后续比较急的补丁都打在stable分支上,然后再回顾这些提交,发布到内核仓库的主干分支。


第二种 Gitflow模式,即多特性分支管理, 比如hadoop

大数据的底层hadoop框架是怎么发行的?


我们看看下图,这就一目了然了。


image.png

一个trunk主干分支,加上现行的主流版本的特性分支(branch-2.10, branch-3.2等)。


别看有trunk分支就是咬定了是trunk-based开发模式,我们要看这个产品活跃分支。


hadoop框架诞生很早,应用比较广泛,属于应用型上层框架。

很多企业用的版本都不是统一个的3.X新版本,不少企业还是2.X版本。所以hadoop社区采用这种分支管理模式,长期维护了多个主流版本的开发。这点学委觉得是非常合适的。


就像下图一样,每一个弯都是一个PR(Pull Request):


image.png

学委想指出,这里出现了多个长分支,像feature1.x, feature

2.x(当然hadoop现在不维护1.x版本了),这个图只是展示作用。


这样的好处:


各个分支的开发独立运作,hadoop 2.X项目主要还是基于Java7运行环境执行。而hadoop 3.X 跟Java8运行。


这样提高了不同分支的独立行,兼顾发行效率。毕竟java7跟java8有不少区别的。


坏处最关键的就是:合并的风险!


随着时间发展,这些大分支积累的patch和主干分支积累的新开发特性,总需要一个时间合并起来,这时候需要很多工作进行合并校对应对一个相对大的工程。


这些大量代码合并往往需要配套不止集成测试,还有回归测试。(当然主干分支需要这套,但是主干分支可以保存每天测完,这个是多分支管理无法比拟的)


延伸 - 自己的项目该如何选择?

非常简单,如果是个人开发者,直接走TBD(Trunk Based Development)。比较简单,随时可以打一个tag,发布一个版本。


如果是一个百人团队,那么学委建议根据实际考虑了。


统一业务平台(二开或者传统大型平台)多团队多项目开发,建议走Git Flow(feature branch模式)多分支模式开发,保证各个项目团队的独立性,同时缩短定期合并的周期。


微服务多组件的单个平台,可以走TBD,划分业务的服务单元保证多个业务单元独立开发,同时分化一个核心平台组管理开发平级别需求。


思考的核心,是把平台规划好,让它支持TBD模式,避免出现大规模合并,除了开发测试成本,这个需要很大量管理介入协调!


目录
相关文章
|
6月前
|
SQL NoSQL Linux
『GitHub项目圈选11』推荐5款本周 深受开发人员青睐 的开源项目
『GitHub项目圈选11』推荐5款本周 深受开发人员青睐 的开源项目
132 1
|
6月前
有关学习如何管理团队的书籍推荐
有关学习如何管理团队的书籍推荐
88 0
|
自然语言处理 Java Go
项目总监必看:如何利用Git深度统计团队代码贡献?多语言实践教程揭秘!
项目总监必看:如何利用Git深度统计团队代码贡献?多语言实践教程揭秘!
340 0
|
3月前
|
存储 测试技术 开发工具
企业Git 规范的必要性-阿里云开发者社区
既然认同需要一份 Git 规范,那么这个规范需要规范哪些内容,解决哪些问题。
|
5月前
|
存储 安全 网络安全
AtomGit 代码托管平台评测赛——完整操作指南
AtomGit 代码托管平台评测赛——完整操作指南
57 0
|
架构师 Java 程序员
同事开源我的微服务深度实践笔记到GitHub,短短3天竟吸粉10W+
说Spring成就了Java,Spring是Java程序员必修课之一,应该没人反对吧? 前几年面试最常问的且可以顺利拿到高薪的技能是Spring,随着Spring体系的壮大,除非你在简历上添加Spring Boot和Spring Cloud的技能,才可以打动面试官,而现在,除非是Spring架构的扎实经验,否则难以让面试官高看。 一名合格的Java后端工程师或架构师,至少微服务架构是必须牢牢掌握的,这里也整理了整套微服务架构学习路线,准备作为福利送给大家,可以先看一下重点简图。
置顶两个月!《程序员如何向架构师转型》神作在Github持续霸榜
企业架构在过去十年中取得了长足的进步。随着越来越多新技术出现,充分利用这些因素来将企业架构创建得更好十分重要。通过将新技术集成到企业架构中,即使在困难时期,也能取得丰硕的成果。
|
架构师 Java 程序员
GitHub爆出初级程序员到架构师【程序员能力模型】星标150k
一个优秀的程序员应该有自己的职业规划,并且能够精准的定位自己所处的位置。一般来说,每一个位置都会有明确的划分,并且也应该能够得到相应的岗位待遇。而我们下面就是以北上深(一线城市)的学员做为调研对象,归纳总结了一个程序员从初级程序员到架构师的能力模型。
|
存储 安全 Devops
爆测一周!22年必看最细致代码托管工具测评
网上代码托管选型的文章不少,不过大多内容有点久远,很多最新的平台没有包括进来,个人花了大概一个星期的时间,把目前市面上比较火的代码托管平台(开源托管平台:Github、Gitee;企业级托管平台:Gitlab、阿里云效Codeup、 腾讯Coding)做了一些比较,比较的维度包括速度、成本、产研工具链完整性、安全、统计报表等,希望可以帮助正在进行代码托管选型的技术同行做决策选型。
1648 0
爆测一周!22年必看最细致代码托管工具测评
|
存储 数据可视化 测试技术
专为技术写作人员提供的 7 条 Git 技巧
本文重点介绍在开始使用 Git 和为 Foreman 文档做贡献时经常遇到的挑战。适用于中级 Git 用户。
下一篇
无影云桌面