IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> 一种优雅的Git分支实践 -> 正文阅读

[开发工具]一种优雅的Git分支实践

概述

Git分支是git设计灵魂,该如何设计Git分支才能让开发做到一发入魂呢?这是我们项目立项之处就靠考虑好的,一般而言,分支设计需要满足下面几个点:

1>团队开发中避免开发功能相互干扰

2>各类分支:开发,测试,上线,bug,备份,标签等科学管理

下面就来介绍一种应对中小型项目git分支管理最佳实践。

Git flow

Git flow 流程的发明者Vincent Driessen,传送门:

A successful Git branching model ? nvie.comIn this post I present a Git branching strategy for developing and releasing software as I’ve used it in many of my projects, and which has turned out to be very successful.https://nvie.com/posts/a-successful-git-branching-model/

先摆结论,然后再解释

常用的分支

Master分支

主分支,项目初始点由这个分支发起,后续该分支作为项目版本标记分支,可以理解为备份分支,从这里可以追溯项目发布所有版本。可以从该分支拉起任意项目版本,并能平稳运行。注意:Master分支不允许程序员在此写代码。

Develop 分支

开发分支,初始时居于Master分支创建,团队所有开发代码集中合并的分支。另外,Develop分支维护项目最新代码。

Feature 分支

功能分支,基于Develop分支创建的新分支,用于新功能/新模块的开发。当开发完成之后,需要合并回到Develop分支。这分支是程序员独属分支,不存与团队源码库。

Release分支

当你需要一个发布一个新版本时,基于Develop分支创建一个Release分支。此时需要注意,属于该版本的所有Feature分支需要合并到Develop分支。Release分支创建成功后,对该版本进行测试,改bug,完成后,需要将代码合并到Master和Develop分支。合并到Master分支,会对Master打上标签,表示一个新的版本。合并到Develop分支,需要注意,其他非该版本的Feature分支再没有完成Release分支发布前,不允许合并会Develop分支。

Hotfix分支

当项目上线后,运行发现新的Bug时候,则需要基于Master创建一个Hotfix, 完成Hotfix后,我们合并回Master和Develop分支,所以Hotfix的改动会进入下一个Release版本。

开发案例

步骤1:项目立项后,项目经理初始化好项目,创建Master分支,同时基于Master分支创建Develop分支

?步骤2:项目要新增功能A,需要分2步实现:功能A1, 功能A2

?程序员小明基于Develop分支创建小明Feature分支,完成功能A1, 功能A2 步骤,开发完成后,合并到Develop分支,此时功Develop分支拥有功能A。

步骤3:同时期,项目想尝试创新,尝试实现功能B

??程序员小红基于Develop分支创建小红Feature分支,尝试实现功能B

步骤4:功能A需要紧急上线发布,此时功能B暂缓

1>完成功能A之后,合并到Develop中

2>功能A要上线,在Develop基础上创建Release分支,在该分支完成测试/调试/改bug

3>确认完成之后,将Release分支代码合并到Develop分支,合并到Master分支,标记Tag2

4>在Release合并回Develop分支之前,不允许新的Feature分支合并回Develop。

5>当合并到Master跟Develop分支后,可删可不删

步骤5:功能B开发完成,需要发布

逻辑跟步骤4一样,这里不展开说了。

步骤6:功能AB(Tag3版本)上线之后?,出bug需要修复

1>当出现bug之后,基于Master分支创建Hotfit分支

2>在Hotfit分支完成bug修改,测试通过后,将代码合并到Master分支,打上标签Tag3.1

3>在Hotfit分支完成bug修改,测试通过后,将代码合并到Develop分支,保证Develop分支代码最新。

最后完整版

?

结语

上面就是Git flow模式的操作所有过程,优点是清晰可控,缺点就是操作复杂,需要维护2个长期的分支,Develop跟Master分支。这导致每次操作需要频繁切换分支。

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2022-08-06 11:04:10  更:2022-08-06 11:05:11 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 18:22:24-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计