【gitflow】 概念基本介绍

news/2025/2/12 23:11:24/

gitflow

简介

什么是gitflow?

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

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

  • 如何保证主分支的稳定性?
  • 如何开发新的feature?
  • 如何创建分支名称?分支多了如何管理?如何知道每个分支干嘛的呢?
  • 哪些分支合并了?
  • 哪些分支是release的分支?可以稳定使用的?
  • 如果稳定分支代码出现没有测出来的bug,如何创建分支快速修复?

这个就像写代码,要有个规范一样, 当然我们可以不按照规范来做,git同样能处理。但是定义一个科学的操作规范,往往能让效率事半功倍。

创始人的分享链接:

https://nvie.com/posts/a-successful-git-branching-model/

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

gitflow 流程图

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

在这里插入图片描述

我们来换个角度来理解

在这里插入图片描述

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

主要分为两大类:

  • 主分支(Main Branches)
  • 辅助分支(supporting branches)

拓展开来:

主分支: Master Develop

辅助分支:Feature、Release、Hotfix

gitflow工作流如何使用

刚开始的时候,我们有个master分支,我们要基于master来创建develop

在这里插入图片描述

master

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

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

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

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

develop

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

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

在这里插入图片描述

feature

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

在这里插入图片描述

Release

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

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

在这里插入图片描述

hotfix

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

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

在这里插入图片描述

总结

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

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

http://www.ppmy.cn/news/438822.html

相关文章

【AIGC】16、Vision-Language 模型在视觉任务中的调研

文章目录 一、简介二、基础知识2.1 视觉任务的训练策略2.2 VLM 基础2.2.1 网络结构2.2.2 预训练目标函数2.2.3 评估和下游任务 2.3 数据集 三、迁移学习3.1 使用 prompt tuning 实现迁移学习3.2 通过特征适应来进行迁移学习 四、VLM 的知识蒸馏4.1 目标检测的知识蒸馏4.2 语义分…

如何将两个笔记本电脑进行相互投屏

文章目录) 使用以下定义:实际中:A和B电脑分别安装无线显示器B电脑这么做:A电脑这么做: 使用以下定义: 投影的电脑为:A电脑 待投影的电脑为:B电脑 实际中: A电脑为win1…

了解IT专业,选对IT专业

高考结束后,放松几天后,就要思考自己该选哪个学校、专业等等 做好攻略避免选的不如意。 一、IT专业的就业前景和发展趋势 IT专业的就业前景非常广阔,而且随着技术的不断发展,其发展趋势也是越来越好。根据近几年IT发展的热门就业…

【Python 随练】今天是哪一天?

题目: 输入某年某月某日,判断这一天是这一年的第几天? 简介: 在本篇博客中,我们将使用Python代码解决一个日期相关的问题:如何确定某一天是给定年份的第几天。我们将提供问题的解析,并给出一…

LeetCode——查询后矩阵的和

目录 1、题目 2、题目解读 3、代码 1、题目 2718. 查询后矩阵的和 - 力扣(Leetcode) 给你一个整数 n 和一个下标从 0 开始的 二维数组 queries ,其中 queries[i] [typei, indexi, vali] 。 一开始,给你一个下标从 0 开始的…

iOS 集成Jenkins pipeline 自动打包并上传蒲公英

文章目录 1 创建一个Jenkins pipeline 项目Pipeline script打包和上传蒲公英脚本 1 创建一个Jenkins pipeline 项目 上面那几个配置项其实不用关心的,我们这里先实现一个简单的能够打包的流程 这里只配置Pipeline script Pipeline script 主要的流程都是有pipe…

【Python 随练】三数字排序

题目: 输入三个整数 x, y, z,请按照从小到大的顺序输出这三个数。 简介: 在本篇博客中,我们将使用Python代码解决一个简单的排序问题:如何将输入的三个整数按照从小到大的顺序进行排序并输出。我们将提供问题的解析…

Q4净利润同比增长46.5% 腾讯音乐终于“好听又好看”了?

北京时间3月17日,腾讯音乐对外公布2019年第四季度及全年业绩。财报显示,腾讯音乐娱乐集团本季度不少核心指标均超市场预期,整体表现都还不错。因财报好于预期,财报公布后,腾讯音乐娱乐集团的股价盘后逆势上涨4%。 从股…