0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是gitflow?gitflow工作流如何使用?

冬至子 来源:RTT_逍遥 作者:RTT_逍遥 2023-08-03 15:40 次阅读

简介
什么是gitflow?

我们大家都很会用git,但是我们很少去关心我们要怎么用branch和版本控制。

只知道master是第一个主分支,其他分支都是次要分支, 那你知道如下的问题如何回答吗?

如何保证主分支的稳定性?
如何开发新的feature?
如何创建分支名称?分支多了如何管理?如何知道每个分支干嘛的呢?
哪些分支合并了?
哪些分支是release的分支?可以稳定使用的?
如果稳定分支代码出现没有测出来的bug,如何创建分支快速修复?
这个就像写代码,要有个规范一样, 当然我们可以不按照规范来做,git同样能处理。但是定义一个科学的操作规范,往往能让效率事半功倍。

gitflow 是一种git分支模型,是由创始人Vincent Driessen 2010年创建的。这只是一种建议,在团队合作中,具体项目中要灵活应用,不用可守成规,觉得不合理的地方可以自行修正。

gitflow 流程图
我们来看下创始人最初的流程图:

1.jpg

我们来换个角度来理解

1.jpg

gitflow的核心要素是branch,通过branch来实现工作流。

主要分为两大类:

主分支(Main Branches)
辅助分支(supporting branches)
拓展开来:

主分支: Master Develop

辅助分支:Feature、Release、Hotfix

gitflow工作流如何使用
刚开始的时候,我们有个master分支,我们要基于master来创建develop

1.jpg

master
master分支上存放的是最稳定的版本,并且该分支的代码是随时可以让用户使用的代码,就是非常非常稳定的代码。当一个版本开发完成之后,交付给客户的时候,master上面的额代码也要被更新。同时,每次更新都要打上相应的tag。

任何人不允许在master上进行代码的直接push提交,只接受其他分支合入。原则上master分支必须是release的分支合过来的代码。

来源只能是:hotfix和release分支。不能是其他分支。

master一定是经过多轮测试,但是不能保证完全没有bug,所以引入hotfix分支,来修复未知bug

develop
develop是主开发分支,这个分支上被合并的代码始终是下一个版本需要加入的feature。这个分支可以合并一些feature。当要release的时候,就从这个分支上进行创建release分支。

合并到develop分支上的必须保证功能完整,不影响develop分支的正常运行。

1.jpg

feature
feature 分支又叫功能分支,一般命名方法feature/xxx,用来开发版本或者未来要发布新的功能或者探索新功能。(feature 分支功能要保证里面的commit 的粒度要非常细,避免和主分支脱节严重,应该大功能切成一个一个小功能来merge,而不是一次merge一个大的)

1.jpg

Release
这个分支又叫预发布分支,一般命名为 release/1.1.x 这个分支转为发布做准备。允许小量级的bug修复。

release分支只能从develop分支拉过来,用来修复一些bug。(不做feature相关的开发)

1.jpg

hotfix
hotfix 叫热修复分支,一般命名为hotfix/4.1.3 为固定某个版本进行修复,当master上遇到严重问题需要修复的时候,就要从master上指定tag拉取。这样做就是为了隔离feature开发和bug修复。

hotfix只能从master上拉去,测试通过之后合并会master和develop

1.jpg

总结
有些人觉得gitflow好用,有些人觉得gitflow太死板,太复杂,团队里面每个人都要遵守这套规则,会很麻烦。毕竟规则越复杂,用起来越难。所以创始人也建议团队根据实际情况调整策略。我觉得有以下几点值得注意:

团队主要成员如果成员固定,并且训练有素,可以考虑用一下。团队人员如果太多,太杂,不建议。如果主要团队人员就1-2个人,也不建议。
从时间点上来说,要将团队统一战线,比如master要开始release了,整个团队需要切到release分支去修复bug,并且坚决不允许有feature合入。大feature可以下一个版本进行合并。
release要全部测试人员测试完成,没有bug了,再合到master上。
一定要保证master上面的有个稳定的代码源(这个是最重要的一点,如果达不到,产品化效果会很差)
不同的团队保持并行开发,相互之间干扰要降到最低。
没有比较完善的测试团队,不建议用,因为如果不能保证master分支上的代码足够稳定,在修复bug的时候,要频繁hotfix到master和develop以及release上,如果过多,这个是比较恐怖的事情。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 控制器
    +关注

    关注

    112

    文章

    15558

    浏览量

    173557
  • 隔离器
    +关注

    关注

    4

    文章

    680

    浏览量

    38039
收藏 人收藏

    评论

    相关推荐

    71.git工作流:6.1 gitflow工作流介绍 #硬声创作季

    服务器代码
    充八万
    发布于 :2023年07月12日 19:29:18

    E8.Net工作流90%以上源代码提供~

    E8.Net工作流开发架构,快速开发实施软件项目:  E8.Net工作流是国内商业流程管理(BPM)领域在.Net平台上的领先产品,是快速搭建大型流程管理自动化解决方案的IT技术
    发表于 03-31 11:17

    基于工作流技术的广州电信本地计费系统改造

    【作者】:龙欣庭【来源】:《华南理工大学》2009年【摘要】:工作流指业务过程的部分或整体在计算机应用环境下的自动化,使多个参与者之间传递信息或任务的过程按照某种预定义的规则自动进行。工作流技术为
    发表于 04-24 09:20

    基于Notes的OA工作流引擎的设计和实现

    到了更高层次的发展,成为企业管理现代化的重要标志。目前,办公自动化技术越来越普遍地被应用到***机关、金融机构和企事业单位的日常管理中,成为提高工作效率、优化管理流程的重要手段。工作流技术的使用,使得
    发表于 04-24 09:22

    基于工作流的零售贷款档案管理系统设计与实现

    课题。工作流技术的应用在企业中逐渐发挥越来越重要的作用。工作流技术是实现业务过程重组与改造的核心技术。工作流技术的应用可以提高生产率,优化业务流程,对企业信息化具有重要的现实意义。可无缝集成到Web服务上
    发表于 04-24 09:22

    协同时光Synchro FLOW,中国特色工作流

    ` 本帖最后由 372345973 于 2013-7-1 16:57 编辑 协同时光工作流基于BPM的应用开发 西安协同时光软件有限公司提供的协同时光工作流产品Synchro FLOW,重视流程
    发表于 07-01 16:55

    AndroidWifi工作流

    AndroidWifi工作流
    发表于 09-25 11:17

    【MPS最佳实践】媒体工作流转码

    常用视频处理流程。优势简单易用,视频上传完成自动触发转码任务。功能强大,支持截图、转码、转封装、水印、加密、剪辑等功能。在媒体工作流开始执行和完成执行时,支持向指定的消息队列或消息通知发送工作流执行
    发表于 02-28 11:15

    Java版开源工作流Jflow如何从表数据数据源导入设置

    Java版开源工作流Jflow从表数据数据源导入设置
    发表于 07-15 06:36

    基于本体和工作流的网络工程实训管理系统研究,不看肯定后悔

    本文根据网络工程实训管理系统的实际应用需要,采用改进的本体和工作流的建模方法进行建模,开发了网络工程实训管理系统,该系统的开发对解决管理系统建立过程中存在的重复规划问题具有参考意义。
    发表于 05-27 06:16

    企业工作流机模型的设计

    工作流机是一个为工作流实例的执行提供运行服务环境的软件或引擎。它是工作流执行服务的核心,是执行企业经营过程的业务操作系统的内核,它的运转也就带动了企业的经营活
    发表于 06-16 09:45 30次下载

    OA系统中工作流引擎的设计

    本文首先介绍了工作流供理系统的概念及其体系结构模型。基于Web 平台,针对模型中工作流引擎模块的设计提出了一个行之有效解决方案。关键字:工作流; 工作流引擎; UML; 用
    发表于 06-16 11:31 45次下载

    工作流环境下组件的开发

    本文基于对工作流环境下组件的开发为目的,采用工作流技术与组件技术相结合的方法,讨论构建工作流组件的方法。通过在开发中结合Ajax技术,使之克服传统的Web应用中同步交换问题
    发表于 12-17 11:01 0次下载
    <b class='flag-5'>工作流</b>环境下组件的开发

    工作流程图怎么用?有哪些绘制工作流程图的软件

    工作流程图是清晰地展示工作中各个环节的流程图图示,主要用于工作活动和效率的管理。工作流程图这种图示方法具有直观描述性、简洁性、可操作性和指导性。工作
    的头像 发表于 07-28 14:22 3284次阅读

    联影磁共振参数工作流卡介绍

    工作流卡提供了临床工作应用相关的参数,主要分为三部分,校准工作流、扫描工作流以及加载工作流,此篇内容以腹部屏气T1压脂序列为例。
    的头像 发表于 05-19 16:07 3316次阅读
    联影磁共振参数<b class='flag-5'>工作流</b>卡介绍