🏀事情起因:
最近翻看博客中小伙伴评论时,发现文章【规范】看看人家Git提交描述,那叫一个规矩一条回复:
本狗亲测在我司中使用规范的好处,遂把我司的Git分支管理规范跟大家分享下,可能与大厂标准流程有些简化区别,望大厂大佬勿喷 。
主分支:
主干分支具有分支保护权限,只有运维有权限进行合并分支 。
分支模型 | 用途 |
---|---|
master | 主干分支,正式版本代码归档 |
develop | 开发分支,团队成员日常开发的主分支 |
doc | 文档分支,SQL脚本、配置等 |
辅助分支:
属于临时分支,当功能合并主干后,会删除清理掉 。
分支模型 | 用途 |
---|---|
feature | 从develop拉取开发的功能分支 |
hotfix | bug修复分支 |
举个例子🌰 。
2024年7月3日,我司敏捷团队进行任务分解后,javadog项目正式开启新的迭代,版本号为v2.1.1 。
✅有什么好处?
保持团队的起始开发分支一致,从同一个起点出发 。
通过develop中拉取新分支:feature-javadog-v2.1.1-SNAPSHOT-20240703 。
记住!记住!记住! 这个feature-javadog-v2.1.1-SNAPSHOT-20240703 叫功能分支 。
开发环境中,自动化部署都是通过这个分支名进行打包,命名解释如下:
✅有什么好处?
团队成员有自己临时开发分支,保证开发灵活性,提测版本稳定性,保证功能分支的健壮稳定性 。
👦张三拉取自己开发临时功能分支:feature-javadog-v2.1.1-SNAPSHOT-20240703-zhangsan 。
🧔李四拉取自己开发临时功能分支:feature-javadog-v2.1.1-SNAPSHOT-20240703-lisi 。
✅有什么好处?
团队成员每完成自己任务并验证后,即可合并提测,提高合作效率,加快提测速度,推进项目进度有序进行 。
张三开发的模块A功能完成,本地调试正常后,将自己临时分支合并到功能分支,流水线由测试小姐姐打包功能分支feature-javadog-v2.1.1-SNAPSHOT-20240703 。
✅有什么好处?
保证功能分支灵活性,并兼顾预生产版本分支,如预生产环境遇到问题,可以在功能分支修复并在开发环境验证,解耦保持稳定性 。
通过功能分支feature-javadog-v2.1.1-SNAPSHOT-20240703,拉取feature-javadog-v2.1.1-20240703 预生产分支,并打出对应tag,然后发布预生产 。
❓什么是蓝绿部署 。
蓝绿部署是一种将生产环境直接从当前版本(蓝色)切换到新版本(绿色)的策略。这要求同时运行两个完全相同的生产环境,但只有一个对外提供服务.
聚个贴近实际的栗子🌰,来讲述蓝绿部署 。
一个蛋糕店,有两个员工分别是"蓝"员工A,和"绿"员工B 。
他们共同推销店里的同一种老蛋糕,也就是线上正在运行的老项目 。
这个时候店长说有新品上市了,就把A员工叫回店里去拿新蛋糕内测一下,也就是让蓝线去发布新需求v2.1.1,这条蓝线也只有店内自己评测,不会影响员工B老蛋糕销售,也就是不会影响线上正式环境 。
当员工A那里的新蛋糕评测完成后,就将B员工叫回店里,将A员工推出店外售卖,这样顾客就可以买到新蛋糕,也就是可以访问新的需求功能 。
当A员工新蛋糕卖的不错,也就是系统稳定后。再进行蓝绿部署平衡,将B员工也拿着新蛋糕和A员工一起售卖,进行合理负载 。