近期困惑于Git代码版本控制,集中两天时间研究,其中基础知识来源于《Git权威指南》,分支思想则来源于一篇博文《A successful Git branching model》(作者:Vincent Driessen,原文链接:http://nvie.com/posts/a-successful-git-branching-model/),细读之下,受益匪浅,仅于此文记录心得,详细内容请参考原文。

Main Branch

master

主分支,代表着部署(生产)环境最新版本的代码状态,即代码始终与部署环境最新版本代码保持一致;

develop

开发分支,代表着即将发布的下一个版本的代码状态;也可以理解为“整合”分支,开发新特性或修复Bug过程中产生的新代码需要定期合并至开发分支,用于“每日”构建。

当开发分支(develop)中的代码稳定到一个可发布的状态时,需要被合并至主分支(master),由主分支创建相应版本(Tag)。

Supporting Branch

Feature

特性分支,用于开发新的功能特性,生命周期如下:

(1)需要开发新的功能特性时,从开发分支创建一个或多个特性分支;

git checkout -b myfeature develop

(2)新的功能特性开发完成时,特性分支需要合并至开发分支;

git checkout develop
git merge --no-ff myfeature

(3)删除特性分支;

git branch -d myfeature

(4)推送开发分支至远程版本库;

git push origin develop

注:特性分支仅存在于开发者的本地环境中,一般不将其推送至远程版本库。

Release

发布分支,特定版本发布之前的“准备”分支,用于测试或Bug修复,生命周期如下:

(1)某一个版本的功能特性全部开发完成(即该版本的所有功能特性分支已全部合并至开发分支)之后、正式发布之前需要创建相应的发布分支;

git checkout -b release-1.2 develop

注:之所以需要创建发布分支,是因为发布分支一旦创建完成,发布分支测试或修复Bug的过程中,开发分支可同时用于下一个版本的代码开发。

(2)更新、提交版本信息;

./bump-version.sh 1.2
git commit -m "Bumped version number to 1.2"

bump-version.sh只是一个示例脚本,用于更新版本文件中的版本号,也可以根据实际情况手动更新版本号。

(3)测试或Bug修复,均在此发布分支中进行;

(4)测试或Bug修复完成之后,合并至主分支、创建版本、推送至远程版本库;

git checkout master
git merge --no-ff release-1.2
git push origin master git tag -m "Version 1.2" 1.2
git push origin 1.2

(5)也需要合并至开发分支、推送至远程版本库;

git checkout develop
git merge --no-ff release-1.2
git push origin develop

(6)删除发布分支;

git branch -d release-1.2

注1:为什么不是发布分支合并至开发分支,再由开发分支合并至主分支?这是因为发布分支在测试或Bug修复过程中,开发分支可能会参与下一个版本的代码开发,这样做当前版本的代码中可以混合有下一个版本尚为完成的代码。

注2 :发布分支合并至主分支及开发分支时,由于涉及到版本号更新,因具体方式不同,可能会出现冲突;合并至主分支时,以发布分支为主;合并至开发分支时,以开发分支为主。

Hotfix

修复分支,用于修复已发布版本中存在的Bug,生命周期如下:

(1)某一个已发布版本存在Bug时,需要从相应版本创建修复分支,修复Bug及测试;

git checkout -b hotfix-1.2.1 1.2

(2)更新、提交版本信息;

./bump-version.sh 1.2.1
git commit -m “Bumped version number to 1.2.1”

(3)修复Bug及测试完成之后,创建新版本,并推送至远程版本库;

git tag -m "Version 1.2.1” 1.2.1
git push origin 1.2.1

(4)也需要合并至开发分支,并推送至远程版本库;

git checkout develop
git merge --no-ff hotfix-1.2.1
git push origin develop

(5)删除修复分支;

git branch -d hotfix-1.2.1

注1:修复分支(1)与(3)原文描述不相符,主要出于以下几个方面的考虑:

(1)主分支(master)仅维护最新版本代码;

(2)部署环境可能同时使用多个版本代码,且版本之间存在代码不兼容的情况;

(3)Bug可能出现在比较“旧”的版本中;

如果任何一个版本的Bug修复都从主分支创建修复分支,然后再合并至主分支,可能会导致代码混乱。

注2:合并至开发分支可以使得后续新发布的版本中不再包含已修复的Bug。

注3:修复特定版本的Bug时,需要在“大”版本号(1.2)的基础之上创建“小”版本号。

Code Deploy

代码部署,并不在原文讨论范围之内,但也是非常重要的一点,这里仅描述一下自己的方式:

git clone

git pull

git checkout

注:可以通过版本文件中的版本号确认具体版本信息。

Git Flow具体方式方法差异化较大,争议较多,欢迎指正讨论。

Git Flow Note的更多相关文章

  1. GIT FLOW 时序图

    git flow sequence md link: git branching model master->master branch: use default branch Note rig ...

  2. Git Flow 分支管理简述

    概述 Git 是什么 Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的 ...

  3. Git flow 工作流与规范

    概述 简版图: PS. 可能用到的命令: 1.从指定 commit拉出新分支   git checkout commitId -b 本地新branchName git checkout 9fbc3d0 ...

  4. Git 在团队中的最佳实践--如何正确使用Git Flow

    我们已经从SVN 切换到Git很多年了,现在几乎所有的项目都在使用Github管理, 本篇文章讲一下为什么使用Git, 以及如何在团队中正确使用. Git的优点 Git的优点很多,但是这里只列出我认为 ...

  5. Git 在团队中的最佳实践--如何正确使用Git Flow[转]

    原文地址:http://www.cnblogs.com/cnblogsfans/p/5075073.html Git的优点 Git的优点很多,但是这里只列出我认为非常突出的几点. 由于是分布式,所有本 ...

  6. 基于git的源代码管理模型——git flow

    基于git的源代码管理模型--git flow A successful Git branching model

  7. git flow的使用

    简介 Gitflow工作流程围绕项目发布定义了严格的分支模型.尽管它比Feature Branch Workflow更复杂一些,但它也为管理更大规模的项目提供了坚实的框架. 与Feature Bran ...

  8. 引入git flow分支管理

    git flow是Vincent Driessen提出了一个分支管理的策略,非常值得借鉴.它可以使得版本库的演进保持简洁,主干清晰,各个分支各司其职.井井有条. 先看下Vincent Driessen ...

  9. git flow的安装和使用

    确保安装了git 1.windows系统下安装 进入cmd clone github上的gitflow到一个文件夹下 我这里clone到 c:\gitflow git clone git://gith ...

随机推荐

  1. 手机自动化测试:appium源码分析之bootstrap四

    手机自动化测试:appium源码分析之bootstrap四   Orientation是调整屏幕方向的操作 package io.appium.android.bootstrap.handler; i ...

  2. WCF消息压缩

    对于WCF应用来说,传输前压缩请求消息和回复消息,不但可以降低网络流量,也可以提高网络传输的性能 一.消息压缩方案 二.用于数据压缩与解压缩组件 三.用于消息压缩与解压的组件 四.用于对请求/回复消息 ...

  3. (读书笔记)函数参数浅析-JavaScript高级程序设计(第3版)

    ECMAScript函数不介意传递的参数个数,因为在其内部是用一个数组进行表示的.在函数体内可以通过arguments对象来访问这个参数数组,就像我们正常访问数组一样处理. arguments对象只是 ...

  4. 一个web应用的诞生(11)--在探首页

    就要面对本章的一个难点了,说是难点可能仅仅对于我来说,毕竟我是一个js渣,既然首页打算使用动态加载的形式,那么与后台交互的方式就要进行选择,目前比较流行的为RESTful的形式,关于RESTful的文 ...

  5. MySQL之数据类型(常用)

    MySQL-data_type数据类型 1.查看数据类型 mysql> help data type    //通过help对数据进行查看,以及使用的方法 2.MySQL常见的数据类型 整数in ...

  6. Android系统--输入系统(六)模拟输入驱动程序

    Android系统--输入系统(六)模拟输入驱动程序 1. 回顾输入子系统 简单字符设备驱动:应用程序通过调用驱动所实现的函数使能硬件. 输入子系统:由于有多个应用程序使用输入子系统,故肯定使用的是早 ...

  7. 浩哥解析MyBatis源码(十一)——Parsing解析模块之通用标记解析器(GenericTokenParser)与标记处理器(TokenHandler)

    原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6724223.html 1.回顾 上面的几篇解析了类型模块,在MyBatis中类型模块包含的 ...

  8. angular购物车

    <body ng-app> <div class="container" ng-controller="carController"> ...

  9. WinForm中控件位置不随窗体大小的变化而改变

    背景:在窗体开发中使控件的位置不随窗体的大小改变而变化的问题?这是一个同事在开发时遇到的问题,在思考试错之后,写出如下代码. 声明成员: Point m_InitLocation; Size m_In ...

  10. 读书笔记 effective c++ Item 51 实现new和delete的时候要遵守约定

    Item 50中解释了在什么情况下你可能想实现自己版本的operator new和operator delete,但是没有解释当你实现的时候需要遵守的约定.遵守这些规则并不是很困难,但是它们其中有一些 ...