GitFlow工作流程

1.什么是Gitflow

Gitflow是基于Git的强大分支能力所构建的一套软件开发工作流,最早由Vincent Driessen在2010年提出

2.Gitflow特征

在Gitflow的模型里,软件开发活动基于不同的分支:

  • master 该分支上的代码随时可以部署到生产环境
  • develop 作为每日构建的集成分支,到达稳定状态时可以发布并merge回master
  • Feature branches 每个新特性都在独立的feature branch上进行开发,并在开发结束后merge回develop
  • Release branches 为每次发布准备的release candidate,在这个分支上只进行bug fix,并在完成后merge回master和develop
  • Hotfix branches 用于快速修复,在修复完成后merge回master和develop

3.例子

前置阶段(新功能启动)

  • 开发组长
    • 基于master主干创建一个develop分支

现有主干分支: masterdevelop

开发阶段(开始开发)

  • 程序猿
    • 基于develop分支创建一个feature_login(语义化)分支
    • feature_login分支上开发新功能
    • 测试新功能完成以后,在git上发起Pull request把代码合并到到develop分支上(千万不要提交合并到master)
  • 开发组长
    • 确认代码没问题,通过该合并请求

现有主干分支: masterdevelopfeature_login

测试阶段(开发完毕)

  • 开发组长
    • 基于develop分支创建一个分支名为release-1.0.0的预发布版本
  • 测试
    • release-1.0.0分支的代码进行测试
    • 测试通过在git发起Pull requestrelease-1.0.0代码合并到到master分支上

现有主干分支: masterdevelopfeature_loginrelease-1.0.0

发布阶段(测试通过)

  • 开发组长
    • 基于master分支创建一个里程碑版本(tag)名为1.0.0-Release
    • 删除完成使命的其他分支:feature_loginrelease-1.0.0

现有主干分支: masterdevelop1.0.0-Release(tag)


线上代码出现bug时,各角色的工作流程

前置阶段(提交bug)

  • 用户或者测试
    • 基于1.0.0-Release里程碑版本在git上新建一个issue

现有主干分支: masterdevelop1.0.0-Release(tag)

修复阶段(开始修复bug)

  • 程序猿
    • 基于1.0.0-Releasetag创建一个hotfix_0001(该issue序号)分支
    • hotfix_0001分支上修复bug
    • 测试代码没问题,在git上发起Pull request把代码合并到到master主干上
  • 开发组长
    • 确认代码没问题,通过该合并请求

现有主干分支: masterdevelop1.0.0-Release(tag)、hotfix_0001

测试阶段(bug修复完毕)

  • 测试
    • master分支的代码进行测试

现有主干分支: masterdevelop1.0.0-Release(tag)、hotfix_0001

发布阶段(测试通过)

  • 开发组长
    • 基于master分支创建一个里程碑修复版本(tag)名为1.0.1-Release
    • 删除完成使命的其他分支:hotfix_0001

现有主干分支: masterdevelop1.0.0-Release(tag)、1.0.1-Release(tag)


 

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Gitflow 是一种流行的 Git 工作流程,它定义了一组严格的分支命名规则和分支的作用,可以帮助团队更好地管理 Git 代码库。 Gitflow 工作流程包含以下分支: 1. `master` 分支:主分支,用于发布稳定版本的代码。 2. `develop` 分支:开发分支,包含最新的开发版本。 3. `feature` 分支:用于开发新功能的分支,从 `develop` 分支创建,开发完成后合并回 `develop` 分支。 4. `release` 分支:用于发布新版本的分支,从 `develop` 分支创建,完成测试后合并回 `master` 和 `develop` 分支。 5. `hotfix` 分支:用于修复线上问题的分支,从 `master` 分支创建,完成修复后合并回 `master` 和 `develop` 分支。 Gitflow 工作流程的基本流程如下: 1. 开发者从 `develop` 分支创建一个新的 `feature` 分支,进行开发。 2. 当新功能开发完成后,开发者将 `feature` 分支合并回 `develop` 分支。 3. 确认下一个版本的发布时间后,从 `develop` 分支创建一个新的 `release` 分支,进行测试和修复问题。 4. 当 `release` 分支测试完成后,将其合并回 `master` 分支和 `develop` 分支,并打上版本号的标签。 5. 如果在线上发现了问题,从 `master` 分支创建一个新的 `hotfix` 分支进行修复修复完成后将其合并回 `master` 和 `develop` 分支。 通过 Gitflow 工作流程,团队可以更好地管理代码库,隔离不同分支的开发和发布,提高代码质量和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值