【Tool/Git】git-flow

本文详细介绍了GitFlow的工作原理、各分支角色(如master、develop、feature、release、hotfix)及其操作流程,涵盖了创建、合并和发布的基本步骤,以及GitFlow在项目管理中的实际应用。
摘要由CSDN通过智能技术生成

小解

master: 主分支
devlop: 开发分支;所有功能的集合分支;
feature:功能分支;开发部分功能;开发完成后,被 develop 分支 merge;
release: 待发布分支,来自develop分支;可以进行最后的 bug 修复和功能验证;
hotfix:master bug 修复分支;修复后被 master,develop分支merge;

  1. master 分支每个提交必须有 tag
  2. 所有的 feature 分支必须是从 develop分支创建
  3. release 分支每次只能有一个,正式发布以后才能创建其它release 分支
  4. 发布 release 分支后;release 分支必须被 master、develop 分支 merge
  5. 每次merge 后删除目标分支
  6. 每次完成分支后删除目标分支

Git flow工具

安装
OS X
brew install git-flow

Linux
apt-get install git-flow

Windows
wget -q -O - --no-check-certificate https://github.com/nvie/gitflow/raw/develop/contrib/gitflow-installer.sh | bash

使用

  • 每个flow 操作主要有 start publish pull finish 三种操作
    初始化: git flow init
  1. feature start : git flow feature start MYFEATURE

  2. feature publish (也就是push到远程): git flow feature publish MYFEATURE

  3. feature pull : git flow feature pull origin MYFEATURE

  4. feature finish : git flow feature finish MYFEATURE

  5. release start : git flow release start RELEASE [BASE]git flow release start RELEASE

  6. release publish :git flow release publish RELEASE

  7. release finish : git flow release finish RELEASE
    别忘了git push --tags

  8. hotfix start: git flow hotfix start VERSION [BASENAME]git flow hotfix start VERSION

  9. hotfix finish: git flow hotfix finish VERSION

在这里插入图片描述

git-flow 流程图,如下:

在这里插入图片描述

Git Flow常用的分支

  1. Production 分支
    也就是我们经常使用的Master分支,这个分支最近发布到生产环境的代码,最近发布的Release, 这个分支只能从其他分支合并,不能在这个分支直接修改

  2. Develop 分支
    这个分支是我们是我们的主开发分支,包含所有要发布到下一个Release的代码,这个主要合并与其他分支,比如Feature分支

  3. Feature 分支
    这个分支主要是用来开发一个新的功能,一旦开发完成,我们合并回Develop分支进入下一个Release

  4. Release分支
    当你需要一个发布一个新Release的时候,我们基于Develop分支创建一个Release分支,完成Release后,我们合并到Master和Develop分支

  5. Hotfix分支
    当我们在Production发现新的Bug时候,我们需要创建一个Hotfix, 完成Hotfix后,我们合并回Master和Develop分支,所以Hotfix的改动会进入下一个Release

Git Flow如何工作

初始分支
注:所有在Master分支上的Commit应该Tag

在这里插入图片描述
Feature 分支
分支名 feature/*

Feature分支做完后,必须合并回Develop分支, 合并完分支后一般会删点这个Feature分支,但是我们也可以保留
在这里插入图片描述
Release分支
分支名 release/*

Release分支基于Develop分支创建,打完Release分之后,我们可以在这个Release分支上测试,修改Bug等。同时,其它开发人员可以基于开发新的Feature (记住:一旦打了Release分支之后不要从Develop分支上合并新的改动到Release分支)

发布Release分支时,合并Release到Master和Develop, 同时在Master分支上打个Tag记住Release版本号,然后可以删除Release分支了。
在这里插入图片描述

维护分支 Hotfix
分支名 hotfix/*

hotfix分支基于Master分支创建,开发完后需要合并回Master和Develop分支,同时在Master上打一个tag
在这里插入图片描述

Git Flow代码示例

a. 创建develop分支

git branch develop
git push -u origin develop    
b. 开始新Feature开发

git checkout -b some-feature develop
# Optionally, push branch to origin:
git push -u origin some-feature    

### 做一些改动    
git status
git add some-file
git commit    
c. 完成Feature

git pull origin develop
git checkout develop
git merge --no-ff some-feature
git push origin develop

git branch -d some-feature

# If you pushed branch to origin:
git push origin --delete some-feature    
d. 开始Relase

git checkout -b release-0.1.0 develop

# Optional: Bump version number, commit
# Prepare release, commit
e. 完成Release

git checkout master
git merge --no-ff release-0.1.0
git push

git checkout develop
git merge --no-ff release-0.1.0
git push

git branch -d release-0.1.0

# If you pushed branch to origin:
git push origin --delete release-0.1.0   


git tag -a v0.1.0 master
git push --tags
f. 开始Hotfix

git checkout -b hotfix-0.1.1 master    
g. 完成Hotfix

git checkout master
git merge --no-ff hotfix-0.1.1
git push


git checkout develop
git merge --no-ff hotfix-0.1.1
git push

git branch -d hotfix-0.1.1

git tag -a v0.1.1 master
git push --tags

友情链接
声明:本博客部分图片或文章内容来源于网络,版权归原作者所有,如有侵权,请与我联系删除。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值