初识 Git 工作流程

栏目: 编程工具 · 发布时间: 5年前

内容简介:Git已是代码版本管理的标配,其分布式、多分支功能让人印象深刻。当项目需要多人共同开发时,规范工作流程就变得越来越重要。合适的工作流程能让多人协同开发更加顺利和高效。目前主流的Git工作流程有三种:
初识 Git 工作流程

Git已是代码版本管理的标配,其分布式、多分支功能让人印象深刻。

Git工作流程(Git Workflow)

初识 Git 工作流程

当项目需要多人共同开发时,规范工作流程就变得越来越重要。合适的工作流程能让多人协同开发更加顺利和高效。

目前主流的Git工作流程有三种:

三种工作流程各有优缺点,对于不同类型的项目有各自的用武之地。笔者开发Android项目时使用的是Git Flow,对此比较熟悉。其余两种工作流程,笔者出于学习的目的,在文中谈谈自己的理解。

Git Flow

从分支分类开始,有以下几类:

长期分支、主要分支

  • master (主分支):稳定可发布、产品线
  • develop (开发分支):处于开发状态
初识 Git 工作流程
git checkout -b develop master
git push origin develop
复制代码

短期分支、支持性分支

  • feature (功能分支)
  • release (发布分支)
  • hotfix (修复分支)

feature 功能分支

初识 Git 工作流程
git checkout -b feature-main develop
# git commit 1
# git commit 2
# git commit 3
git checkout develop
git merge --no-ff feature-main
git branch -d feature-main
git push origin develop
复制代码

--no-ff

初识 Git 工作流程

release 发布分支

初识 Git 工作流程
git checkout -b release-1.0 develop
# 可能在该阶段再分出 fix-* 分支来修复发布前的问题,会有git commit和 git merge 操作。
复制代码

发布分支已测试完毕,问题已修复,可发布时,将代码同步到 master 分支中。

git checkout master
git merge --no-ff release-1.0
git tag -a v1.0
git push origin master
git push origin v1.0
复制代码

若在发布分支中有修复问题,那么这些提交也要同步到 develop 分支中。

git checkout develop
git merge --no-ff release-1.0
git push origin develop
复制代码

删除发布分支。

git branch -d release-1.0
复制代码

hotfix 修复分支

当线上版本有紧急问题需要修复, develop 分支还处于下一个版本的开发状态,不好从开发分支分出修复分支,选择从 master 分出 hotfix-* 分支来修复该紧急问题。

初识 Git 工作流程
git checkout -b hotfix-1.2.1 master
git commit -a -m "Bumped version number to 1.2.1"
复制代码

该紧急问题被修复,并验收通过时发布修复版本,同步代码到 master 分支。

git checkout master
git merge --no-ff hotfix-1.2.1
git tag -a v1.2.1
git push origin master
git push origin v1.2.1
复制代码

接着将代码同步到 develop 分支。

git checkout develop
git merge --no-ff hotfix-1.2.1
git push origin develop
复制代码

删除修复分支。

git branch -d hotfix-1.2.1
复制代码

实际操作中,会将 master 作为开发分支,因为它几乎是Git相关 工具 的默认分支,可以省去大量切换工作。新建诸如 releaseproduction 分支作为产品分支。

GitHub Flow

初识 Git 工作流程

只有一个长期分支 master ,很适合持续发布的项目,如:网站,相比Git Flow 更简单、易用。

初识 Git 工作流程
git checkout -b bug47833 master
git commit
git checkout master
git merge --no-ff bug47833
git push origin master
复制代码

GitLab Flow

只有一个主分支 master 。该工作流程最大原则是“上游优先”,只有 master 分支的代码提交,才能应用到下游分支中。

在开发需求或修复问题时,可以使用GitHub Flow方式从 master 分支分出工作分支,开发完成后以合并请求合并到 master 分支,当验收通过时,就可以合入到下游分支并发布了。

持续发布

初识 Git 工作流程

版本发布

初识 Git 工作流程

结束语

本文主要介绍了3种Git工作流程,其中重点介绍了Git Flow。目前笔者所在的团队使用的工作流程类似于GitLab Flow,在这里只是简单的介绍,而GitHub Flow工作流程未真正实践过,出现在文中是为了丰富文章内容。

文中的Git工作流程并不是全部,完全可以自己按需扩展或全新定义出适合项目的工作流程。


以上所述就是小编给大家介绍的《初识 Git 工作流程》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法设计与分析基础

算法设计与分析基础

Anany Levitin / 潘彦 / 清华大学出版社 / 2015-2-1 / 69.00元

作者基于丰富的教学经验,开发了一套全新的算法分类方法。该分类法站在通用问题求解策略的高度,对现有大多数算法准确分类,从而引领读者沿着一条清晰、一致、连贯的思路来探索算法设计与分析这一迷人领域。《算法设计与分析基础(第3版)》作为第3版,相对前版调整了多个章节的内容和顺序,同时增加了一些算法,并扩展了算法的应用,使得具体算法和通用算法设计技术的对应更加清晰有序;各章累计增加了70道习题,其中包括一些......一起来看看 《算法设计与分析基础》 这本书的介绍吧!

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具