Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
GIT
【gitflow】 概念基本介绍
发布于 2023-06-13 21:14:47 浏览:317
订阅该版
[tocm] # gitflow ## 简介 什么是gitflow? 我们大家都很会用git,但是我们很少去关心我们要怎么用branch和版本控制。 只知道master是第一个主分支,其他分支都是次要分支, 那你知道如下的问题如何回答吗? - 如何保证主分支的稳定性? - 如何开发新的feature? - 如何创建分支名称?分支多了如何管理?如何知道每个分支干嘛的呢? - 哪些分支合并了? - 哪些分支是release的分支?可以稳定使用的? - 如果稳定分支代码出现没有测出来的bug,如何创建分支快速修复? 这个就像写代码,要有个规范一样, 当然我们可以不按照规范来做,git同样能处理。但是定义一个科学的操作规范,往往能让效率事半功倍。 创始人的分享链接: https://nvie.com/posts/a-successful-git-branching-model/ git flow 官方文档: https://danielkummer.github.io/git-flow-cheatsheet/index.zh_CN.html gitflow 是一种git分支模型,是由创始人Vincent Driessen 2010年创建的。这只是一种建议,在团队合作中,具体项目中要灵活应用,不用可守成规,觉得不合理的地方可以自行修正。 ## gitflow 流程图 我们来看下创始人最初的流程图: ![image-20230605220649099.png](https://oss-club.rt-thread.org/uploads/20230613/7e4a030cefed2c9da6656abd05842c2c.png.webp) 我们来换个角度来理解 ![image-20230605220818073.png](https://oss-club.rt-thread.org/uploads/20230613/e83ab3ef2a3546b0d48f2636ee1c2b1d.png.webp) gitflow的核心要素是branch,通过branch来实现工作流。 主要分为两大类: - 主分支(Main Branches) - 辅助分支(supporting branches) 拓展开来: 主分支: Master Develop 辅助分支:Feature、Release、Hotfix ## gitflow工作流如何使用 刚开始的时候,我们有个master分支,我们要基于master来创建develop ![image-20230605221216611.png](https://oss-club.rt-thread.org/uploads/20230613/143e462fa789137a1d8b65efbedb021a.png) ### master **master分支上存放的是最稳定的版本**,并且该分支的代码是随时可以让用户使用的代码,就是非常非常稳定的代码。当一个版本开发完成之后,交付给客户的时候,master上面的额代码也要被更新。同时,每次更新都要打上相应的tag。 **任何人不允许在master上进行代码的直接push提交,只接受其他分支合入**。原则上master分支必须是release的分支合过来的代码。 **来源只能是:hotfix和release分支。不能是其他分支。** master一定是经过多轮测试,但是不能保证完全没有bug,所以引入hotfix分支,来修复未知bug ### develop develop是主开发分支,这个分支上被合并的代码始终是下一个版本需要加入的feature。这个分支可以合并一些feature。当要release的时候,就从这个分支上进行创建release分支。 **合并到develop分支上的必须保证功能完整,不影响develop分支的正常运行。** ![image-20230605222948819.png](https://oss-club.rt-thread.org/uploads/20230613/148ebeee1bc859dfcde268ddc179c064.png.webp) ### feature feature 分支又叫功能分支,一般命名方法feature/xxx,用来开发版本或者未来要发布新的功能或者探索新功能。(feature 分支功能要保证里面的commit 的粒度要非常细,避免和主分支脱节严重,应该大功能切成一个一个小功能来merge,而不是一次merge一个大的) ![image-20230605222907831.png](https://oss-club.rt-thread.org/uploads/20230613/2872892dccb12cef773c8b22626369fd.png.webp) ### Release 这个分支又叫预发布分支,一般命名为 release/1.1.x 这个分支转为发布做准备。允许小量级的bug修复。 release分支只能从develop分支拉过来,用来修复一些bug。(不做feature相关的开发) ![image-20230605222828146.png](https://oss-club.rt-thread.org/uploads/20230613/22334252e044469c2fe220bf79c2826b.png.webp) ### hotfix hotfix 叫热修复分支,一般命名为hotfix/4.1.3 为固定某个版本进行修复,当master上遇到严重问题需要修复的时候,就要从master上指定tag拉取。这样做就是为了隔离feature开发和bug修复。 hotfix只能从master上拉去,测试通过之后合并会master和develop ![image-20230605222739195.png](https://oss-club.rt-thread.org/uploads/20230613/bf2d88a60ae0060640d9671a47d85d17.png.webp) # 总结 有些人觉得gitflow好用,有些人觉得gitflow太死板,太复杂,团队里面每个人都要遵守这套规则,会很麻烦。毕竟规则越复杂,用起来越难。所以创始人也建议团队根据实际情况调整策略。我觉得有以下几点值得注意: - 团队主要成员如果成员固定,并且训练有素,可以考虑用一下。团队人员如果太多,太杂,不建议。如果主要团队人员就1-2个人,也不建议。 - 从时间点上来说,要将团队统一战线,比如master要开始release了,整个团队需要切到release分支去修复bug,并且坚决不允许有feature合入。大feature可以下一个版本进行合并。 - release要全部测试人员测试完成,没有bug了,再合到master上。 - 一定要保证master上面的有个稳定的代码源(这个是最重要的一点,如果达不到,产品化效果会很差) - 不同的团队保持并行开发,相互之间干扰要降到最低。 - 没有比较完善的测试团队,不建议用,因为如果不能保证master分支上的代码足够稳定,在修复bug的时候,要频繁hotfix到master和develop以及release上,如果过多,这个是比较恐怖的事情。 # 提问 不知道大家的有没有观察自己公司有没有用到git flow呢?欢迎评论区留言聊聊公司中的策略。 我相信一定有很多小伙伴觉得公司branch怪怪的,但是又不知道为什么这样命名,希望这篇文章能帮助到大家。
7
条评论
默认排序
按发布时间排序
登录
注册新账号
关于作者
RTT_逍遥
https://github.com/supperthomas
文章
33
回答
491
被采纳
72
关注TA
发私信
相关文章
1
用GIT GUI的时候每次PUSH都要手动填一遍目标仓库地址?
2
git上面的图片加载不出来,有其他可以看BSP 制作教程的方法吗
3
gitee这几个版本怎么分别
4
packages 的 git失败
5
软件包的镜像地址怎么找呢
6
关于tortoisegit的push操作
7
RTT Studio 内置git 推送不到远程gitee仓库
8
git软件包失败下载失败,找不到CA路径?
9
studio内置的git该如何使用
10
RT-Thread studio的git功能可以直接使用吗?
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
国产MCU移植系列教程汇总,欢迎查看!
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
Bootloader
AT
ART-Pi
Hardfault
CAN总线
FinSH
USB
文件系统
DMA
RT-Thread
SCons
线程
RT-Thread Nano
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
ota在线升级
WIZnet_W5500
I2C_IIC
UART
flash
cubemx
packages_软件包
freemodbus
潘多拉开发板_Pandora
PWM
定时器
ADC
BSP
中断
编译报错
socket
keil_MDK
GD32
flashDB
Debug
MicroPython
msh
ulog
SFUD
SDIO总线
rt_mq_消息队列_msg_queue
本月问答贡献
出出啊
1506
个答案
339
次被采纳
小小李sunny
1423
个答案
281
次被采纳
张世争
740
个答案
161
次被采纳
crystal266
539
个答案
157
次被采纳
whj467467222
1218
个答案
146
次被采纳
本月文章贡献
出出啊
1
篇文章
5
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
3
篇文章
7
次点赞
crystal266
2
篇文章
1
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
投诉
建议
回到
底部