谈谈我眼里的 git flow

一、前言

最近接手的一个内部孵化项目进入了紧张的迭代开发期,一周至少需要完成 5 个功能以及 N 个历史 Bug 修复工作。之前项目只有一个人负责,因此所有的开发都在 git 的 develop 分支里开发,开发完毕后合并到 master 上。

但是现在为了满足敏捷开发、快速迭代的需求,后端项目组增加了 2 名成员,结果发现只在 develop 分支上开发的问题弊端过多,问题出现在:

  1. 大家的代码经常发生冲突,基本上一天有 5% 的时间要解决冲突问题
  2. 生产环境上遇到紧急的问题无法正常修复,每次修复都直接在服务器上修改,然后再同步回本地,结果造成大量无效时间。

为了解决此问题,我决定在小组内启用 git flow 开发模式,本文也当做一个简单的组内学习教程,也希望对其他人有用。

二、什么是 Git Flow?

关于什么是 Git Flow 估计在百度上能搜出一大堆,但用我的话来总结就是:

git flow 是利用 git 分支让团队协作能无干扰顺利进行的工作流程

它的主要特点有以下几个方面:

  1. 让处于半成品状态的功能(feature)不会影响到主分支(master)
  2. 各个开发人员之间做自己的分支,互不干扰
  3. 主分支(master)永远处于可编译、可运行的状态

以下是 git flow 流程图(是的,这个图肯定也烂大街了,将就看看)


git flow

主要分支介绍

  • master 分支:主分支,产品的功能全部实现后,最终在 master 分支对外发布。
  • develop 分支:开发分支,基于 master 分支克隆,产品的编码工作在此分支进行。
  • release 分支:测试分支,基于 delevop 分支克隆,产品编码工作完成后,发布到本分支测试,测试过程中发现的小 bug 直接在本分支进行修复,修复完成后合并到 develop 分支。本分支属于临时分支,目的实现后可删除分支。
  • bugfix 分支:Bug 修复分支,基于 master 分支或发布的里程碑 Tag 克隆,主要用于修复对外发布的分支,收到客户的 Bug 反馈后,在此分支进行修复,修复完毕后分别合并到 develop 分支和 master 分支。本分支属于临时分支,目的实现后可删除分支。
  • feature 分支:功能特征分支,基于 develop 分支克隆,主要用于多人协助开发场景或探索性功能验证场景,功能开发完毕后合并到 develop 分支。feature 分支可创建多个,属于临时分支,目的实现后可删除分支。

三、工具安装

工欲善其事必先利其器,我们可以通过以下命令在操作系统里安装好 git-flow 扩展集,简化我们的操作流程:

Mac 系统运行以下命令安装:

$ brew install git-flow-avh

Linux 系统运行以下命令安装:

$ apt-get install git-flow

Windows 系统运行以下命令安装

$ wget -q -O - --no-check-certificate https://raw.github.com/petervanderdoes/gitflow-avh/develop/contrib/gitflow-installer.sh install stable | bash

更具体的安装步骤可以访问此篇文章了解:git-flow 备忘清单

四、场景使用介绍(跟着我练 10 遍)

下面我将模拟出真实的使用场景,每个场景都需要大家敲入正确的代码:

现在公司的官网系统正在 master 分支上平稳运行着,当前计划在 10 天后上线一个新版本,增加投稿功能。

目前公司安排甲、乙、丙三人负责此项目,大家领取的功能如下:

  • 甲负责增加投稿功能的前端代码(contribute-frontend)
  • 乙负责投稿功能的后端代码,并需要嵌套前端逻辑(contribute-server)
  • 丙负责增加投稿相关的后台管理功能(contribute-admin)

具体情况如下:

  • 项目进行到第 1 天,所有人都创建好了各自的开发分支,平稳的开发者;
  • 项目进行到第 3 天,领导发现用户的注册登录功能有问题,安排甲去负责修-复;甲在当天正常修复,并通知给领导以及乙和丙,让他们同步代码;
  • 项目进行到第 5 天,丙率先完成后台功能;
  • 项目进行到第 6 天,甲完成前端功能;
  • 项目进行到第 7 天,乙完成后台功能以及前端嵌套;
  • 项目进行到第 8 天,丙发布了内测版本;
  • 项目进行到第 9 天,甲和乙在内测过程中都发现了开发问题,并及时提交修复;
  • 项目进行到第 10 天,正式上线;

题目就是:
根据以上每一天的场景,列出当天任务责任人所需要输入的 git flow 命令。如:

## 项目第 1 天,三个人需要运行以下命令创建自己对应的分支
甲:git flow feature start contribute-frontend
乙:git flow feature start contribute-server
丙:git flow feature start contribute-admin

。。。以下是其他的内容

以上就是常见的使用场景了,在这篇文章里不会给出答案,希望大家都能按照自己理解的方式做做此练习。做完一遍后可以反复多做几遍,让自己的身体形成肌肉记忆,提高工作效率 :)

参考

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354

推荐阅读更多精彩内容

  • 多种多样的工作流使得在项目中实施Git时变得难以选择。这份教程提供了一个出发点,调查企业团队最常见的Git工作流。...
    JSErik阅读 4,403评论 2 8
  • 世事无常,疾病是现在的家常便饭,有人说:疾病虽可以治愈,但是癌呢?我想说,怀着一颗憧憬,向往的心,无论是什么疾病,...
    书漫ing阅读 193评论 0 1
  • 关于银行存管,还是想再多说一点点,所以我就随了自己的性子,今天又来侃侃了。 昨天那篇文章,有个建行的小伙伴如是说,...
    郑雨洁阅读 310评论 0 0
  • 、供给毫无弹性: 时间的供给量是固定不变的,不会增加、也不会减少,每人每天只有24小时,所以我们无法开源。 2、无...
    祁红莲阅读 9,488评论 0 2