摘要:聊一聊Git中的工作流——分支策略。

本文分享自华为云社区《Git工作流中常见的三种分支策略:GitFlow、GitHubFlow以及GitLabFlow》,原文作者:敏捷的小智。

前言

版本控制系统是指对软件开发过程中程序代码、配置文件、文档等发生的变更进行管理的系统,它可以帮助团队更好的沟通协作,从而更好的进行交付,常见的版本控制系统分为集中式版本控制系统(如SVN)和分布式版本控制系统(如Git)。

之前拜访一家企业,企业内的开发团队使用Git管理日常开发工作,在开发过程中遇到一个问题:分支策略使用很混乱——最初开发团队从主干分支拉出一条特性分支,但新功能完成后,该特性分支没有合入主干分支,而是作为下次开发的主干分支,重新拉出一条新的特性分支,导致主干分支一直形同虚设,团队没有一条稳定的代码分支。

这个问题很大程度上源于团队对分支策略的不了解,本文就简单聊一聊Git中的工作流——分支策略。

常见的分支策略

上文中提到的团队使用分支策略很混乱,这种分支策略也并不是主流的,使用主流的分支策略则会避免以上问题。

常见的分支策略有以下三种:GitFlow、GitHubFlow以及GitLabFlow。

Git Flow

GitFlow是这三种分支策略中最早出现的。

GitFlow通常包含五种类型的分支:Master分支、Develop分支、Feature分支、Release分支以及Hotfix分支。

  • Master分支:主干分支,也是正式发布版本的分支,其包含可以部署到生产环境中的代码,通常情况下只允许其他分支将代码合入,不允许向Master分支直接提交代码(对应生产环境)。
  • Develop分支:开发分支,用来集成测试最新合入的开发成果,包含要发布到下一个Release的代码(对应开发环境)。
  • Feature分支:特性分支,通常从Develop分支拉出,每个新特性的开发对应一个特性分支,用于开发人员提交代码并进行自测。自测完成后,会将Feature分支的代码合并至Develop分支,进入下一个Release。
  • Release分支:发布分支,发布新版本时,基于Develop分支创建,发布完成后,合并到Master和Develop分支(对应集成测试环境)。
  • Hot fix分支:热修复分支,生产环境发现新Bug时创建的临时分支,问题验证通过后,合并到Master和Develop分支。

通常开发过程中新特性的开发过程如下:

从Develop分支拉取一条Feature分支,开发团队在Feature分支上进行新功能开发;开发完成后,将Feature分支合入到Develop分支,并进行开发环境的验证;开发环境验证完成,从Develop分支拉取一条Release分支,到测试环境进行SIT/UAT测试;测试无问题后,可将Develop分支合入Master分支,待发版时,直接将Master分支代码部署到生产环境。

可参考下图:

GitFlow的优点是每个分支都有明确的定义,严格按照GitFlow管理项目代码的话,很难出现代码混乱;其缺点是:如果特性分支过多的话很容易造成代码冲突,从而提高了合入的成本;由于每次提交都涉及多个分支,所以GitFlow也太不适合提交频率较高的项目。

使用华为云 DevCloud 实现 Git Flow

1.创建分支

华为云DevCloud的代码托管功能支持端到端的GitFlow,我们在代码仓库中可新建分支,如图,目前已有主要分支:Master分支和Develop分支,和两个特性分支:Feature-Bill和Feature-Score分支。

2.为分支创建流水线

流水线功能需要在华为云DevCloud的流水线功能中进行配置,基于“Feature-Bill”分支新建一条流水线。

在流水线中配置构建、部署任务,以便于对Feature-Bill分支代码的构建、部署进行验证(构建、部署等任务需要提前在对应模块下创建)。

3.Feature提交代码并验证

Feature-Bill分支开发完成后,提交代码即可触发流水线进行验证。

4.代码合入 Develop 分支进行验证

同理还需要为Develop分支创建一条流水线,当Feature-Bill分支通过merge命令合入到Develop分支之后,由于Develop分支的代码发生了变化,也会触发流水线进行验证。

Develop分支验证没问题后,团队可以拉取Release分支,创建并启动Release分支的流水线进行测试环境验证。若发现缺陷,可直接在Release分支进行修改、验证。当测试环境验证通过后,将代码合入Master分支,创建并启动Master流水线进行生产环境升级与验证。

GitHubFlow

GitHubFlow看名字也知道和GitHub有关,它来源于GitHub团队的工作实践。当代码托管在GitHub上时,则需要使用GitHubFlow。相比GitFlow而言,GitHubFlow没有那么多分支。

GitHubFlow通常只有一个Master分支是固定的,而且GitHubFlow中的Master分支通常是受保护的,只有特定权限的人才可以向Master分支合入代码。

在GitHubFlow中,新功能开发或修复Bug需要从Master分支拉取一个新分支,在这个新分支上进行代码提交;功能开发完成,开发者创建Pull Request(简称PR),通知源仓库开发者进行代码修改review,确认无误后,将由源仓库开发人员将代码合入Master分支。

很多人可能会问,提交代码通常是commit或者push,拉取代码才是pull,为什么GitHubFlow中提交代码提出的是“Pull Request”。因为在GitHubFlow中,PR是通知其他人员到你的代码库去拉取代码至本地,然后由他们进行最终的提交,所以用“pull”而非“push”。

GitHubFlow优点是相对于GitFlow来说比较简单,其缺点是因为只有一条Master分支,万一代码合入后,由于某些因素Master分支不能立刻发布,就会导致最终发布的版本和计划不同。

GitLabFlow

GitLabFlow出现的最晚,GitLabFlow是开源工具GitLab推荐的做法。

GitLabFlow支持GitFlow的分支策略,也支持GitHubFlow的“Pull Request”(在GitLabFlow中被称为“Merge Request”)。

相比于GitHubFlow,GitLabFlow增加了对预生产环境和生产环境的管理,即Master分支对应为开发环境的分支,预生产和生产环境由其他分支(如Pre-Production、Production)进行管理。在这种情况下,Master分支是Pre-Production分支的上游,Pre-Production是Production分支的上游;GitLabFlow规定代码必须从上游向下游发展,即新功能或修复Bug时,特性分支的代码测试无误后,必须先合入Master分支,然后才能由Master分支向Pre-Production环境合入,最后由Pre-Production合入到Production。

GitLabFlow中的Merge Request是将一个分支合入到另一个分支的请求,通过Merge Request可以对比合入分支和被合入分支的差异,也可以做代码的Review。

华为云DevCloud也支持GitLabFlow的合并请求,以保护主干分支不收干扰。

1.设置保护分支

仓库管理员在代码托管的“设置”中,选择“保护分支管理”,然后将Master(或Develop)分支设定为保护分支,普通开发者不可向Master分支提交代码、也不允许合入代码,只有仓库管理员才可以向Master分支提交代码或合入代码。

2.创建合并请求

在代码仓库的“合并请求”中,创建一条合并请求,请求将Feature-Bill分支合入develop分支。

并指定评审人员和执行合入操作的人员。

3.Review代码并通过合并请求

相关人员收到合并请求后,可以通过“文件变更”,比对文件前后的变化,确认无误后,可执行合入操作,如果有冲突可线上或线下解决冲突。

除了执行合并操作,还可以对代码进行评论打分,为Feature-Bill分支的合入提供建议。

总结

分支策略不同,研发效率也不同,没有最好的分支策略,只有最适合团队的分支策略,各分支策略的优缺点在上面已经列出,大家可以根据团队情况,选择合适的分支策略进行开发。

点击关注,第一时间了解华为云新鲜技术~

Git工作流中常见的三种分支策略:GitFlow、GitHubFlow和GitLabFlow相关推荐

  1. 分布式事务中常见的三种解决方案

    分布式事务中常见的三种解决方案 目录 一.分布式事务前奏 二.柔性事务解决方案架构 (一).基于可靠消息的最终一致性方案概述 (二).TCC事务补偿型方案 (三).最大努力通知型 三.基于可靠消息的最 ...

  2. 虚拟化中常见的三种硬盘模式

    虚拟化中常见的三种硬盘模式 1.厚置备延迟置零: 默认的创建格式,创建过程中为虚拟磁盘分配所需空间.创建时不会擦除物理设备上保留的任何数据,没有置零操作,当有IO操作时,需要等待清零操作完成后才能完成 ...

  3. 学习笔记 --- 编码过程中常见的三种异步方式

    实际的编码过程中, 凡是涉及到网络通信的代码, 异步都是决不可缺少的. 那么什么是异步呢? 异步就是子线程, 异步通过开辟子线程来实现, 所以一提到异步就应该想到子线程. 即使不涉及网络通信, 异步也 ...

  4. JAVA共有几种窗体布局方式_在Java GUI程序开发中常见的三种布局管理器是什么

    答:FlowLayout 流式布局,从左到右,如果到边界就换行再从左到右. BorderLayout 边界布局(默认布局方式),按东西南北中五个方向来布局,默认是中.后设置在同样位置的控件会覆盖之前的 ...

  5. python中常见的三种选择结构_在Python中,实现多分支选择结构的最佳方法是

    在Python中,实现多分支选择结构的最佳方法是 答:if-elif-else 绘制建筑平面图时,被剖切的墙用 线绘制,定位轴线用 线绘制 答:粗实 细点画 智慧职教: 下列关于书写住院病历的叙述不正 ...

  6. oracle 表连接 大表小表_优化必备基础:Oracle中常见的三种表连接方式

    在Oracle SQL语句中,如果from后面有多个表时,表的连接方式是一个很重要的考量. 从Oracle 6开始,优化器就支持下面4种表连接方式: - 嵌套循环连接(Nested Loop Join ...

  7. python中while语法格式_python中常见的三种句型if,while,for

    原博文 2016-06-28 23:26 − 1.if语句: 特别说明:条件后面的冒号不能少,同样必须是英文字符. 特别特别说明:if内部的语句需要有一个统一的缩进,一般用4个空格.python用这种 ...

  8. C++ vector容器中常见的三种遍历方式

    1.迭代器 for (std::vector<int>::iterator it = vecTest.begin(); it != vecTest.end(); ++it){tempNum ...

  9. js基础语法(01)-JS中+号的三种含义

    01-JS中+号的三种含义 (1)数学意义上的相加 : 1 + 1 会得到: 2 (2) 数学意义上的正负号: +5 正数 作用:可以把string类型转换成number类型 (3)字符串的连接符:' ...

最新文章

  1. pandas describe函数_PANDAS: 新手教程 一
  2. 最短路问题的原始对偶算法形式
  3. Android关于绘图中Shader 的效果(中级)
  4. SMB文件共享及用户权限使用配置
  5. 避免误删文件:Linux回收站机制
  6. Number Theory Problem(The 2016 ACM-ICPC Asia China-Final Contest 找规律)
  7. 【笔记】MATLAB中的图形(2)
  8. [Android Pro] 终极组件化框架项目方案详解
  9. java swing进度条_Java Swing创建自定义闪屏:在闪屏上添加Swing进度条控件(转)
  10. python爬去朋友圈_利用Python爬取朋友圈数据,爬到你开始怀疑人生
  11. Android 系统(164)---手机收到8bit编码的短信无法显示
  12. instr函数 mysql_mysql数据库中查找字串出现的位置instr函数
  13. 西安石油大学计算机类分专业,西安石油大学2019年分专业录取分数解读
  14. CDN技术详解及实现原理
  15. html中title属性和alt属性的区别
  16. 网卡设置不当造成断线
  17. UG NX 工程图视图概述
  18. html5 讯飞离线语音包,讯飞输入法离线语音怎么用?讯飞输入法离线语音开启方法...
  19. 谷歌浏览器翻译插件推荐——Google Chrome 插件推荐
  20. 【NVivo教程】使用Nvivo扩展文献综述

热门文章

  1. android 代码中使用dp,简单谈谈Android中SP与DP的区别
  2. destroy意思中文翻译_destroy是什么意思_ destroy的翻译_音标_读音_用法_例句_爱词霸在线词典...
  3. chosen jquery ajax搜索,基于chosen插件实现人员选择树搜索自动筛选功能
  4. html 图像 ppt,用HTML设置的文本和图像.ppt
  5. nginx上配置phpmyadmin
  6. SpringMVC(二)高级
  7. Web前端和后端开发的区别和要求
  8. 2018.4.23 数据结构
  9. 正则表达式基础知识,持续更新…
  10. angular使用Md5加密