我常用的 Git 开发工作流

我常用的 Git 工作流

目前,绝大部分的互联网公司,开发都是使用 GitLab 或者 Github 作为代码的托管所。

想分享一下个人日常工作的流程,从新做一个需求到需求代码合入。

使用到的工具:Git + Sourcetree

Git 项目地址:plaid 仓库

封面

面对部门的一个工程仓库「以 https://github.com/android/plaid 为例」,我会采用 fork 的形式, 这样在自己的空间里面就会有一个对应名称的工程仓库。

分为以下步骤:

1. Fork 仓库到自己的空间中

https://github.com/android/plaid 点击 Fork , 会拷贝一份当前的仓库到自己的空间

例如:


fork 按钮

此时会在自己的空间下出现一个 Fork 工程的项目:

Fork 的好处是,你可以随便在自己空间下的仓库中,修改各种内容。

然后拷贝该仓库的 SSH,我们在终端中可以使用 git clone 把当前这个仓库代码下载到电脑本地:

// 下载到本地
git clone git@github.xxx/plaid.git
// xxx 为你的 github 的账号名称

2. 添加 remote 信息

fork 到本地后,如何保持和源仓库的代码同步呢?

切换到本地该项目的目录,我们可以使用 git remote add xxx 的方式去添加源仓库的地址:

// 进入该项目目录
cd plaid
// git remote add [名称] [源仓库地址]
git remote add plaid git@github.com:android/plaid.git

同时可以使用 git remote -v 查看该仓库的 remote 信息:

remote 信息

当我们想要跟新自己仓库的代码,保持和源仓库的代码一致,我们需要:

// git fetch plaid ,plaid 是你为远端源仓库起的名字
git fetch plaid
//  想要同步本地 develop  分支的代码
git rebase plaid/develop
// 更新远端 develop 代码;origin 是你 git 空间下该仓库的名称,默认
git push origin develop

这样一来,本地的代码就和源仓库的 develop 分支保持一致了。

注:git remote add [名称]
这里的名称,个人喜欢和源仓库的名称一致,用作区分不同的 remote 信息
当然你可以 add 多个远端地址, 例如 git remote add zhangsan git@github.com:zhangsan/plaid.git

3. 新建分支,完成需求

当我们需要完成需求时,往往需要新建分支。这也是我们日常工作的一种方式,每一个需求对应一个分支,便于后面找问题时及时定位。

比如我们的需求是新增标签,期望上线的版本是 x.y 「例如 5.30 版本」

新建分支:feature_5.30_add_tag

// 新需求,从 develop 拉取分支
git checkout develop
// 更新远端代码
git fetch plaid
// 更新本地 develop 分支
git rebase plaid/develop
// 新建分支:git checkout -b feature_x.y_xxx
git checkout -b feature_5.30_add_tag

这样一个新的分支就会被成功创建,然后在新的分支上开始自由的开发。

分支的名字: 我为什么这么取名字?
主要还是为了便于区分以下内容:

  1. 当前分支是什么?「新需求还是 bugfix
  2. 什么时候上?「5.30」版本
  3. 这个需求是关于什么的?「add_tag
  4. 一个好的分支名字,可以快速帮忙其他人熟悉业务需求

注:

  1. 新需求我会以:feature_5.30 开头
  2. bugfix 我会以 fix_5.30 开头

4. 需求完成后,如何提交?

从我们的 remote -v有多个时,就决定了我们是以 MR「merge request」 的形式向远端仓库提交代码合入的。

注: 在 GitLab 中被称为 Merge Request ;
GitHub 中被称为 Pull Request
两者没有本质区别。可参考这里

为什么呢?因为我们通常会把 developrelease 分支保护起来,我们不能允许直接向这两类分支合入代码,为了工程的安全考虑,转而通过 MR 的方式,经由 Code Review 后合入。

那么 MR 如何提交呢?

// 添加修改的改动
git add .
// 提交修改的改动
git commit -m "提交标签代码"
// push 到你空间下工程的远端
git push origin feature_5.30_add_tag

这时,git 的默认配置下,会生成一个链接,如下所示 :

push 后

点击链接即可创建一个新的 MRPR , 如下:

MR详情

然后填写各项信息,最后点击 create pull request 即可。

这样便会创建一个从 origin/feature_5.30_add_tagplaid/develop 合并的 MR.

注:这里的具体界面不同的公司应该是不同的,这里举例使用的 github 上的样式。
所以,截图上的样式出现的是 pull request, 这里不用在意,本质上是一样的工作原理。

5. 在 MR 合并过程中,会出现的问题

首先,我们需要经过 Code Review ,确认代码不会引入问题,才会合进去;
其次在合并的过程中,可能会出现需要 rebase local 的操作,这是因为我们要合入的分支「develop」已经有其他的 MR 合入了,为了避免代码冲突,需要我们本地先把代码对齐我们要合入的分支 「develop

5.1 Code Review

我们写的代码,一般需要经过 Code Review 才行,在 MR 上,有一项 changes 可以看到本次 MR 所修改的代码。

通过这种方式可以看到我们本次的改动,可以进行代码 review.

开篇时提到一款工具,Sourcetree
Sourcetree ,我常常用它来看我当前的代码改动,因为用这个看会比较方便「相比 AS 自带」。

例如, 选中多个 commit , 看这些 commit 的代码改动:

代码改动

两述两种方式都行,看个人操作习惯。

5.2 解决冲突,更新代码

通常会有两种方式,一种是 rebase; 一种是 merge;

关于两者的区别,在这里不再介绍。

个人推荐使用, merge

  1. merge 会新建立一个提交 commit ,便于后续的代码追踪;
  2. 同时,当代码冲突时,merge 更加友好,一次性解决所有的冲突,而 rebase 会一个一个 commit 解决,比较繁琐。

示例如下:

// merge 操作
// 从 feature_5.30_add_tag 分支切换到 develop
git checkout develop
// 拉取源代码远端最新
git fetch plaid
// 本地 develop 分支更新为最新
git rebase plaid/develop
// 切换到上一个分支,即:feature_5.30_add_tag
git checkout -
// 把本地的 「develop」 分支向 「feature_5.30_add_tag」 分支 merge 代码;
git merge --no-ff develop
...
// 解决冲突或其他问题
...

注: 当代码冲突时,一定要仔细,不可概括的处理。曾经遇到过,同事只要代码冲突时就选择 accept others 的这种操作……「千万不要这样」。

6. 后续

当我们的代码合入之后,此分支也不再具有其他作用,不会继续在此分支上做新的开发。

那么,我们可以开始……新建分支,做新的需求了……(o^^o)

2020.4.26 by chendroid

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

推荐阅读更多精彩内容

  • 多种多样的工作流使得在项目中实施Git时变得难以选择。这份教程提供了一个出发点,调查企业团队最常见的Git工作流。...
    JSErik阅读 4,393评论 2 8
  • 前言 大家好!在下游回来了!不啰嗦快进正题!本篇文章是面对刚开始接触Git的新手,所讲命令并不全,在文章结束会放入...
    老匡话Android阅读 3,917评论 -2 18
  • GitFlow + Gitlab 工作流及规范 一、 git 命令及配置 1.Git ssh 与 gitLab配置...
    allenhai阅读 2,560评论 0 0
  • 初始化 在使用前需要对Git提交用户信息配置git config --global user.name "66"g...
    66pillow阅读 517评论 0 1
  • 这篇博文是自己在学习git过程中的思考总结。本文仅仅代表个人的看法,如有不妥地方还请本文文末留言。 😊 原文链接g...
    Ming_Hu阅读 1,061评论 4 18