【操作】Git版本控制 # 5 相关工作流

github.jpeg

Git操作与git工作流

当我们谈论git时,我们首先会想到版本控制和各种命令及概念。git基础操作请看我的另外一篇文章【操作】git版本控制流入门命令FQ#1

我首先为【Git操作】做一个定义即git命令相关的操作,比如创建分之,合并,提交,撤销等。

【Git工作流】定义为基于git版本控制工具,通过但不限于git命令的正确使用,用于完成版本控制,软件交付的整个流程规范。

git工作流并不是指git相关的操作,当然git相关的操作是git工作流的基础,git工作流更多的是说明基于git仓库管理工具如何更好的开展软件开发工作的一整套流程和规范。


git基本操作

业界主流有三种工作流模式

一 Gitflow工作流

第一种是Gitflow工作流, Gitflow工作流是经典模型,处于核心位置。
以下是一个以gitflow作为工作流的约束范例,可以参考实践

相关术语

master主干

主分支,产品的功能全部实现后,最终在master分支对外发布。用于生产环境发布的完整代码库版本。master主干长期存在,并与生产环境的版本保持一致。

develop分支

开发分支,基于master分支克隆,开发编码测试工作在此分支进行。主要使用git check -b 命令

Git版本控制,主要约定如下

开发人员以分支代码为基准进行开发,测试,并发布测试环境。以主干代码为基准进行灰度环境,生产环境上线部署。原则上,当前主干代码应该以当前线上运行的实际代码保持一致。

主干合并规则

用于经过测试同事验证通过的开发分支,开发人员收到测试邮件之后操作,将开发完成的工作合并到主干分支。主要使用git merge 命令

操作步骤

1 以当前主干为基准进行建立标签里程碑。标签标注以当前线上版本号命名。
2 整理代码,以分支代码为基准进行合并,更新主干代码库。

二 Forking工作流

Forking工作流是分布式github风格的,也叫做github工作流,强调项目fork 和pull request

我们看看go语言开源项目beego的代码贡献说明

beego贡献文档说明.png

看看官方说明文档
github工作流程

image.png

iisues

iisues是提交建议,使用问题,软件bug入口的入口。如果我们想参与一些开源项目,最开始的时候可以从录入iisues,解决iisues开始。

https://github.com/apache/dubbo-admin/issues/421

github-issues.png

图片来源参考文档-对iisues进行标签识别

官方说明文档
https://guides.github.com/features/issues/

三 Gitlab工作流

Gitlab flow 的最大原则叫做"上游优先"(upsteam first),即只存在一个主分支master,它是所有其他分支的"上游"。只有上游分支采纳的代码变化,才能应用到其他分支。

参考官方文档 https://docs.gitlab.com/ee/workflow/gitlab_flow.html

在实际的开发团队中,三种工作流方式一般都会混合使用,根据团队特点,做一些整合。比如采用gitlab界面化系统管理代码,并结合gitflow工作流进行开发。

本文着重提出了业界主流的三种git工作流方式,以及每种工作流的主要特点,并没有细化到具体的使用场景和命令详情。感兴趣的读者,可以以工作流为主线,参考网上对应的文档。从根本上认识三种git工作流,有助于深化理解工作中具体的实际操作。

参考资料

https://github.com/oldratlee/translations/blob/master/git-workflows-and-tutorials/README.md

Git三大特色之WorkFlow(工作流)

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

推荐阅读更多精彩内容

  • 多种多样的工作流使得在项目中实施Git时变得难以选择。这份教程提供了一个出发点,调查企业团队最常见的Git工作流。...
    JSErik阅读 4,417评论 2 8
  • Git的使用以及Git协同工作流的选择 [TOC] 为什么要使用Git Git 是一个分布式的版本管理工具,而且可...
    ghostdemon阅读 686评论 0 0
  • Git 规范 所有使用了本规范的项目,必须严格规范操作,否则不予以合并代码、提测、打包上线等后续操作。 基本要求 ...
    zgsddzwj阅读 13,646评论 1 14
  • 前言 大家好!在下游回来了!不啰嗦快进正题!本篇文章是面对刚开始接触Git的新手,所讲命令并不全,在文章结束会放入...
    老匡话Android阅读 3,928评论 -2 18
  • GIT教程 原创者:文思 一、Git基础 1、认识GIT 有了SVN为何还用GIT? SVN增量式管理,GIT采...
    文思li阅读 2,589评论 0 0