GitFlow入门
1-概述
学会使用 Git 的同时, 也得学会使用 GitFlow, GitFlow 是建立在 Git 的基础之上, 对 Git 命令进行了一次封装.
大多数开发人员使用的 Git 时, 顶多有三个分支: 一个是 master, 一个是 develop, 再就是在 develop 分支上拉出来的开发分支, 或者就是直接在 master 分支上拉出一个分支进行开发.
这样开发比较快速, 对于小团队来说, 已经满足了. 但是随着团队人数的增多, 项目越做越大, 就会出现各种各样的问题, 首当其冲的就是代码功能分布杂乱.
就像代码需要代码规范一样, 代码管理同样需要一个清晰的流程和规范, 这就是 GitFlow.
2-GitFLow分支介绍
一张图让你对 GitFlow 有一个认识:

下面是我对每个分支的理解.
2.1-master 分支
这个分支就是生产分支, 只有 hotfix 分支和 release 分支的代码可以合并进来, 每一次合并都会打一个 tag.
2.2-develop 分支
这个分支是基于 master 创建的, 包含所有下一个 release 分支的代码.
2.3-feature 分支
这个分支是从 develop 分支创建的, 主要用于开发新的功能, 如果功能要发布了, 则合并到 develop 分支.
2.4-release 分支
这个分支是基于 develop 分支创建的, 创建出 release 分支之后, 部署到测试环境, 测试人员进行测试, 如果有问题, 直接在 release 分支上进行修改, 然后合并到 develop 分支, 每一次修改都需要合并待 develop 分支.
如果测试通过, 该分支的使命结束, 将 release 分支的代码分别合并到 master 分支和 develop 分支.
2.5-hotfix 分支
如果 master 版本出现 bug 时, 从 master 上拉取一个 hotfix 分支, 完成 hotfix 后, 合并到 master 分支和 develop 分支.
3-GitFlow命令
简单说, GitFlow 就是把平时我们使用的 git 命令合并起来执行, 本质上可以直接使用普通的 git 命令进行类似 gitflow 的分支管理.
3.1-初始化
使用 git flow init 在现有的 Git 项目中进行初始化, 如果远端有 develop 分支, 需要将本地刚刚初始化的分支和远端相关联(git branch --set-upstream-to=origin/develop develop), 然后拉取远端的代码.
如下:
➜ gitflow git:(master) git flow init
Which branch should be used for bringing forth production releases?
- master
Branch name for production releases: [master]
Branch name for "next release" development: [develop]
How to name your supporting branch prefixes?
Feature branches? [feature/]
Release branches? [release/]
Hotfix branches? [hotfix/]
Support branches? [support/]
Version tag prefix? []
执行完之后, 默认使用 master 作为生产分支, 然后在本地创建一个 develop 分支并切换过去, 然后设置每个特征分支的前缀, 默认即可.
之后我们将 develop 分支推上去(git push -u origin develop).
3.2-feature分支
# 创建一个 feature 分支
git flow feature start feature01
# 推送本地 feature 分支到远端
git flow feature publish feature01
# 拉取远端的 feature 分支到本地
git flow feature pull origin feature01
git flow feature track feature01
# 完成 feature 分支
git flow feature finish feature01
无论在哪个分支上执行 start, 新创建的 feature 分支总是基于 develop 分支进行创建.
无论在哪个分支上执行 finish, 命令执行结束后, feature 分支会被合并到 develop 分支, 然后 feature 分支会被自动删除.
3.3-release分支
# 创建一个 release 分支, 后面的 base: 即提交记录的 sha-1 hash 值, 这个值必须是 develop 分支下的
git flow release start release01 [base]
# 推送本地 release 分支到远端
git flow release publish release01
# 拉取远端的 release 分支到本地
git flow release pull origin release01
git flow release track release01
# 完成 release 分支
git flow release finish release01
无论在哪个分支上执行 start, 新创建的 release 分支总是基于 develop 分支进行创建.
无论在哪个分支上执行 finish, 命令执行结束后, release 分支会被合并到 develop 分支和 master 分支, 然后在 master 分支上打一个 tag, 最后 release 分支被删除.
最后不要忘记 push tag(git push --tags).
3.4-hotfix分支
# 创建一个 hotfix 分支
git flow hotfix start hotfix01
# 完成一个 hotfix 分支
git flow hotfix finish hotfix01
无论在哪个分支上执行 start, 新创建的 hotfix 分支总是基于 master 分支进行创建.
无论在哪个分支上执行 finish, 命令执行结束后, hotfix 分支会被合并到 master 分支, 然后在 master 分支上打一个 tag, 然后 hotfix 分支又合并到了 develop 分支, 最后 hotfix 分支被删除了.
最后不要忘记 push tag(git push --tags).
3.5-support分支
support 功能只是测试版本, 不建议使用.
3.6-tag
4-安装GitFlow
4.1-Mac
brew install git-flow
4.2-CentOS
yum install -y epel-release
yum install -y gitflow
4.3-Ubuntu
apt-get install git-flow
5-客户端工具
当然是 SourceTree.
并不推荐使用客户端工具, 多敲键盘少用鼠标.
6-参考资料
- http://danielkummer.github.io/git-flow-cheatsheet/index.zh_CN.html
- https://www.cnblogs.com/wish123/p/9785101.html
- https://www.git-tower.com/learn/git/ebook/cn/command-line/advanced-topics/git-flow
GitFlow入门的更多相关文章
- android 开发从入门到精通
Android-Tips This is an awesome list of tips for android. If you are a beginner, this list will be t ...
- 学习笔记之Git / Gitflow / TortoiseGit
Git - Wikipedia https://en.wikipedia.org/wiki/Git Git (/ɡɪt/) is a version control system for tracki ...
- Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求
上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...
- ABP入门系列(1)——学习Abp框架之实操演练
作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...
- Oracle分析函数入门
一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...
- Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数
上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...
- Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数
上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...
- Angular2入门系列教程4-服务
上一篇文章 Angular2入门系列教程-多个组件,主从关系 在编程中,我们通常会将数据提供单独分离出来,以免在编写程序的过程中反复复制粘贴数据请求的代码 Angular2中提供了依赖注入的概念,使得 ...
- wepack+sass+vue 入门教程(三)
十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...
随机推荐
- zipkin-client:brave核心代码思路整理
Zipkin是分布式跟踪系统. 简单地理解,可以将Zipkin分为两部分. 一部分为Zipkin Server,其负责接受存储应用程序处理耗时数据,以及UI展示. 另一部分为Zipkin Client ...
- nodejs本版问题
接到一个新项目,前端用的是VUE,这就需要安装nodejs.记得之前安装的是V6.X,在npm install加载依赖库node_modules的时候ant-design-vue总是报错.看到同事用n ...
- Postman系列之发送请求(一)
实验简介 Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件.它能提供功能强大的 Web API 和 HTTP 请求的调试,它能够发送任何类型的HTTP 请求 (GET, ...
- Appium移动自动化测试(五)之应用操作
实验简介 对于APP测试来讲, 除了进行功能测试以外, 安装和卸载其实也是一个很重要的测试项. 试想, 如果用脚本来实现了, 可以事先判断该应用是否已安装, 根据判断结果来执行安装和卸载的动作, 循环 ...
- 热门搜索词获取java版
日常生活中经常会有这样的需求,就是网站上.app上需要展示近期热搜的一些词汇,其实常用的做法当然是自己写爬虫去爬,不过这种办法是在太麻烦了,为了节省时间,可以调用一些接口来实现,比如常用的聚合数据,小 ...
- Docker,用任何工具链和任何语言来构建任何应用
在看过Docker的两个Hello World的程序后,我们对Docker有了一个大概的感性的认识,那么Docker是到底是什么呢?Docker是一个面向开发者和系统管理员编译,装载,和运行分布式应用 ...
- java源码-CountDownLatch源码分析
这次分析CountDownLatch,相信大部分人都用过把! CountDownLatch内部还是Sync对象,还是基础AQS(可见其重要性),首先看一下CountDownLatch初始化,Count ...
- linux常用命令(12)head命令
head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块,head 用来显示档案的开头至标准输出中,而 tail 想当然尔就是看档案的结尾.1 命令格式head [ ...
- [笔记] 基于nvidia/cuda的深度学习基础镜像构建流程 V0.2
之前的[笔记] 基于nvidia/cuda的深度学习基础镜像构建流程已经Out了,以这篇为准. 基于NVidia官方的nvidia/cuda image,构建适用于Deep Learning的基础im ...
- Redis 分库
Redis 可以分库,相当于 MySQL 中的 database.控制数据库总数在 redis配置文件中设置,默认是 16 个.数据库名称是整数索引标识,而不是由一个数据库名称字符串. 选择数据库用 ...