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

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

主干分支管理的好坏:

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

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

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

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

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

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

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

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

我们看看下图,这就一目了然了。
在这里插入图片描述
一个trunk主干分支,加上现行的主流版本的特性分支(branch-2.10, branch-3.2等)。

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

hadoop框架诞生很早,应用比较广泛,属于应用型上层框架。
很多企业用的版本都不是统一个的3.X新版本,不少企业还是2.X版本。所以hadoop社区采用这种分支管理模式,长期维护了多个主流版本的开发。这点学委觉得是非常合适的。

就像下图一样,每一个弯都是一个PR(Pull Request):
在这里插入图片描述

学委想指出,这里出现了多个长分支,像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模式,避免出现大规模合并,除了开发测试成本,这个需要很大量管理介入协调!

文章都在这些专栏里面,喜欢Python的朋友,请关注学习 十年老将带你做开源项目 or Python基础专栏 or Python入门到精通大专栏

持续学习持续开发,我是雷学委!
编程很有趣,关键是把技术搞透彻讲明白。
创作不易,请关注收藏点赞,或者留下评论打打气!

参考链接:

Linux内核Repo: https://github.com/torvalds/linux
Linux稳定版Repo:https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/
Hadoop代码仓库:https://github.com/apache/hadoop/branches

在这里插入图片描述

感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:

① 2000多本Python电子书(主流和经典的书籍应该都有了)

② Python标准库资料(最全中文版)

③ 项目源码(四五十个有趣且经典的练手项目及源码)

④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)

⑤ Python学习路线图(告别不入流的学习)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里无偿获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值