热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Git分支管理实践

背景在团队多人协作开发中,分支管理需要解决如下问题:1.直到上线并验收通过之前,每个人开发的功能互不影响;2.多人开发的功能测试时需要共用同一套(或有限的几套)测试环境;3.哪怕代

背景

在团队多人协作开发中,分支管理需要解决如下问题:



  1. 直到上线并验收通过之前,每个人开发的功能互不影响;

  2. 多人开发的功能测试时需要共用同一套(或有限的几套)测试环境;

  3. 哪怕代码上线后,也有回滚的可能性,上线回滚不会对主干分支的代码产生影响;

  4. 分支管理需要满足快速小步迭代的敏捷开发需求;

我们团队的每个项目有四套环境:
5. 开发环境:开发人员本机或者远程开发环境(我们有几个项目是通过 sftp 远程开发);
6. 测试环境:供测试人员使用;
7. 预发布环境:类生产环境,上线前的回归测试使用;
8. 生产环境:正式发布功能;

根据实践,我们以 gitflow 为基础设计了自己的分支管理流程,该流程已经实践 2 年了,效果很好。


分支管理流程

技术分享图片
说明:



  1. 有 4 种分支:feature/fix、test、release、master。

  2. feature/fix:开发分支/热修复分支。当需要开发新功能或修复 bug 时,开发人员从最新 master 分支创建新的特性分支,在这些分支上进行开发和自测。格式:feature-主开发人姓名-特性描述,如 feature-songlin-coupon-list。这种分支功能上线后即作废,需不定期清理;

  3. test:测试分支。功能开发完成后,开发人员将 feature 分支合并到 test 分支,再将 test 分支发到测试环境供测试人员测试。test 分支属于常驻分支,不过有时候因为操作问题导致污染,需要删掉当前 test 分支,然后从最新 master 创建新的 test 分支(test 重建);

  4. release:功能测试验收完成后,开发人员从最新 master 分支创建 release 分支,按日期命名,格式:release-年月日.当天版本号,如release-20200312.01。将 feature 分支合并到 release 分支,发布到预发布环境给测试验收。预发布验收通过后,将 release 分支发布到生产环境,生产验收成功后将 release 合并到 master 分支。release 也是临时分支,功能上线后即作废;

  5. master:常驻分支,上面的代码和生产环境保持一致。feature 和 release 都是从 master 分支创建的。不能在 master 分支上直接开发,正常情况下也不能用 master 分支发版。release 发布到线上并验证通过后,由项目负责人及时合并到 master 上;

释疑:



  1. 为何使用 release 分支发版而不是直接发 master?
    主要有两个原因。

    一方面,我们需要保证代码直到在生产验收通过之前都是和 master 隔离的,这样一旦代码有问题,不会污染 master,保证别人从 master 拉的代码一定没问题。

    另一方面,该策略能解决多人发版时对 master 分支的竞用问题。比如张三和李四都要发版(假设张三的发版分支是 release-20200401-01,李四的是 release-20200401-02),他俩协商后让张三先发,于是张三的代码先上预发布回归,不料张三的代码在预发布发现了问题,而且需要较长时间修复,此时就可以直接让李四发,由于张三和李四的发版分支是独立的,互不影响。假设是使用 master 发版,那么张三由于已经将代码合到 master 了,此时对 master 造成了污染,需要回退。

    再考虑另一个场景。张三开发了个大功能,现在正在预发布回归,预计要两天时间,此时线上突然出现了个紧急 bug 需要修复,由于张三的代码没有合到 master 上,李四就可以放心地从 master 拉 fix 分支去修复 bug,并插队作紧急上线。



  2. 虽然 release 能解决并行发版问题,但可能会带来发版覆盖问题,如何解决?
    由于代码直到上线并验收通过前都不会合并到 master 上,理论上会出现某人的发版忘记合到 master 上而导致后面的发版把前面的代码覆盖掉的情况。

    实践中我们是通过管理手段来规避这种情况发生的。

    首先,这种模式比较适合小团队(10 人左右),大团队需要划分小组管理。

    我们团队的开发和发版都是有严格规范和审批流程的,开发人员要上生产的时候需要邮件申请,由团队负责人审批。团队负责人一般要做最终代码审核,其中重要的一项就是分支正确性检查(这些工作可能是和项目负责人共同完成的)。另外每个项目都有具体的项目负责人,当有新功能上线并验收通过后,由项目负责人将发版分支合并到 master 分支,并通知团队中各成员,后面发版的需要同步 master 上的最新代码。

    比如前面说的张三和李四的情况,当李四的代码(release-20200401-02)最终合并到 master 上后,张三需要将最新的 master 合到他自己的发版分支上(release-20200401-01),并重新申请预发布回归。




推荐阅读
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 网络爬虫的规范与限制
    本文探讨了网络爬虫引发的问题及其解决方案,重点介绍了Robots协议的作用和使用方法,旨在为网络爬虫的合理使用提供指导。 ... [详细]
  • 本文介绍了 AngularJS 中的 $compile 服务及其用法,通过示例代码展示了如何使用 $compile 动态编译和链接 HTML 元素。 ... [详细]
  • [c++基础]STL
    cppfig15_10.cppincludeincludeusingnamespacestd;templatevoidprintVector(constvector&integer ... [详细]
  • ZooKeeper 入门指南
    本文将详细介绍ZooKeeper的工作机制、特点、数据结构以及常见的应用场景,包括统一命名服务、统一配置管理、统一集群管理、服务器动态上下线和软负载均衡。 ... [详细]
  • 自动验证时页面显示问题的解决方法
    在使用自动验证功能时,页面未能正确显示错误信息。通过使用 `dump($info->getError())` 可以帮助诊断和解决问题。 ... [详细]
  • 本文详细介绍了如何解决DNS服务器配置转发无法解析的问题,包括编辑主配置文件和重启域名服务的具体步骤。 ... [详细]
  • 自定义滚动条美化页面内容
    当页面内容超出显示范围时,为了提升用户体验和页面美观,通常会添加滚动条。如果默认的浏览器滚动条无法满足设计需求,我们可以自定义一个符合要求的滚动条。本文将详细介绍自定义滚动条的实现过程。 ... [详细]
  • importpymysql#一、直接连接mysql数据库'''coonpymysql.connect(host'192.168.*.*',u ... [详细]
  • Framework7:构建跨平台移动应用的高效框架
    Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ... [详细]
  • 本文介绍了如何使用 CMD 批处理脚本进行文件操作,包括将指定目录下的 PHP 文件重命名为 HTML 文件,并将这些文件复制到另一个目录。 ... [详细]
  • 两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ... [详细]
  • 本文详细介绍了DMA控制器如何通过映射表处理来自外设的请求,包括映射表的设计和实现方法。 ... [详细]
  • 解决Win10下MySQL连接问题:Navicat 2003无法连接到本地MySQL服务器(10061)
    本文介绍如何在Windows 10环境下解决Navicat 2003无法连接到本地MySQL服务器的问题,包括启动MySQL服务和检查配置文件的方法。 ... [详细]
author-avatar
gaoxing332844731
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有