Git 常用命令和 Git Flow 梳理

git

用 git 有一段时间了,之前没有详细地了解 git flow,导致协作过程中或多或少出现了一些头疼问题。最近静下心来理了下 git flow 的整个流程,再回头看开朗了不少,总结到这里。介绍的是一些常用的 git 基础命令和 git flow,当然也很重要的,过程中自己在 Github 上建了一个模拟的 Demo 用来熟悉 git flow。其实从理解到动手完成还是有点距离的,笨人有笨法嘛。如有不准确的地方欢迎指正。: )

Git 常用命令

这里列出了一些比较常用的 git 命令,每个命令介绍后面都带一个简单例子~

1. 新开分支

 $ git branch 新分支名
    
 #新建分支 develop
 $ git branch develop

2. 切换到另一个分支

 $ git checkout 分支名

 #切换到 develop 分支
 $ git checkout develop

3. 新开分支并切换到新分支

 $ git checkout -b 新分支名

 #新开 develop 分支,并切换到此分支
 $ git checkout -b develop

4. 查看分支列表

 $ git branch -a

头部带 remotes/origin 的,表示远程分支

5. 查看远程分支列表

 $ git branch -r

6. 向远程仓库提交本地新开的分支

 $ git push origin 新开分支名

 #提交新建的 develop 分支
 $ git push origin develop

7. 删除远程分支

 $ git push origin --delete 远程分支名

 #删除远程仓库中的 develop 分支
 $ git push origin --delete develop

8. 删除本地分支

 $ git branch -d 分支名

 #删除本地的 develop 分支
 $ git branch -d develop

9. 更新分支列表信息

 $ git fetch -p

用于协作时,项目队友添加或删除了远程分支的分支,可以通过这种方式来刷新分支列表信息


Git Flow 梳理

git flow 完整图示

Git 开发模式本质上是一套流程,团队每个成员遵守这套流程以确保完成可控的软件开发过程。原文参考

1.主要分支

在远程仓库中有两个主要分支的生命期可以无限长,分别是:

Master

Develop

develop 和 master 关系图

master 分支(origin/master)

代码仓库中有且仅有的一条主分支,默认为 master ,在创建版本库时会自动创建。所有提供给用户使用的正式版本的源码,都会在这个分支上发布。也就是说主分支 master 用来发布重大版本。

develop 分支(origin/develop)

日常开发工作都会在 develop 分支上面完成。develop 分支可以用来生成代码的最新隔夜版本(nightly builds)。

创建 develop 分支

 $ git checkout -b develop master
 
 #push develop 到远程仓库
 $ git push origin develop

当我们在develop上完成了新版本的功能,最终会把所有的修改 mergemaster 分支。针对每次 master 的修改都会打一个 Tag 作为可发布产品的版本号。

2.辅助分支

开发过程中不可能项目人所有都在一个 develop 分支中开发,版本管理会很混乱。所以除了主要分支外,我们还需要一些辅助分支来协助团队成员间的并行开发。

所用到的辅助分支大体分三类:

  • Feature branches(功能分支)
  • Release branches(预发布分支)
  • Hotfix branches(热修复分支)

通过分支名我们能知道各类型分支都有特定作用,对于他们各自的起始分支和最终的合并分支也都有严格规定。呼,虽然可能会麻烦点,但让人一目了然的效果还是很诱人的。

下面逐一介绍下各类型分支的创建使用和移除方法,过程中我在 Github 中创建一个虚拟的项目用来熟悉整个流程,或许你也可以像我一样做一遍。哈,动手总会有意外收获嘛。废话少说,继续正题~

2.1.Feature branches(功能分支)

feature branches

应用场景:

当要开始一个新功能的开发时,我门可以创建一个 Feature branche 。等待这个新功能开发完成并确定应用到新版本中就合并回 develop,那么如果不是就会被很遗憾的丢弃。。。

应用规则:

  1. develop 分支创建,最终合并回 develop 分支;

  2. 分支名:feature/*;

Tips:这里很多地方说用 feature-* 的方式命名,因为公司项目中用的 feature/*方式,也就习惯了,其实意思是一样的。

(1).Creat a feature branch

 $ git checkout -b feature/test develop

do something in feature/test branch

push 本地 feature/test 到远处代码库;

 $ git push origin feature/test

(2).切换到 develop 合并 feature/test

 $ git checkout develop

 $ git merge --no-ff feature/test

"- -no-ff" 的作用是创建一个新的 "commit" 对象用于当前合并操作。这样既可以避免丢失该功能分支的历史存在信息,又可以集中该功能分支所有历史提交。并且如果想回退版本也会比较方便。

git merge --no-ff 图示

(3).移除本地和远程仓库的 feature/test 分支

 $ git branch -d feature/test

 $ git push origin --delete feature/test

2.2.Release branches(预发布分支)

应用场景:

"Release branches" 用来做新版本发布前的准备工作,在上面可以做一些小的 bug 修复、准备发布版本号等等和发布有关的小改动,其实已经是一个比较成熟的版本了。另外这样我们既可以在预发布分支上做一些发布前准备,也不会影响 "develop" 分支上下一版本的新功能开发。

应用规则:

  1. develop 分支创建,最终合并回 developmaster;

  2. 分支名:release-*;

(1).Creat a release branch

 $ git checkout -b release-1.1 develop
 
 #push 到远程仓库(可选)
 $ git push origin release-1.1

do something in release-1.1 branch

(2).切换到 master 合并 release-1.1

 $ git checkout master

 $ git merge --no-ff release-1.1

 $ git tag -a 1.1

 $ git push origin 1.1

当我们的 release-1.1 的 Review 完成,也就预示着我们可以发布了。打上相应的版本号,再 push 到远程仓库。

(3).切换到 develop 合并 release-1.1

预发布分支所做的修改同时也要合并回 develop

 $ git checkout develop

 $ git merge --no-ff release-1.1

(4).移除本地和远程仓库的 release-1.1

 $ git branch -d release-1.1

 $ git push origin --delete release-1.1

2.3.Hotfix branches(热修复分支)

Hotfix branches 图示

应用场景:

"Hotfix branches" 主要用于处理线上版本出现的一些需要立刻修复的 bug 情况.

应用规则:

  1. master 分支上当前版本号的 tag 处切出,也就是从最新的 master 上创建,最终合并回 developmaster;

  2. 分支名:hotfix-*;

(1).Creat a fixbug branch

 $ git checkout -b fixbug-1.1.1 master
 
 #push 到远程仓库(可选)
 $ git push origin fixbug-1.1.1

do something in fixbug-1.1.1 branch

(2).切换到 master 合并 fixbug-1.1.1

 $ git checkout master

 $ git merge --no-ff fixbug-1.1.1

 $ git tag -a 1.1.1

 $ git push origin 1.1.1`

bug 修复完成,合并回 master 并打上版本号;

(3).切换到 develop 合并 fixbug-1.1.1

 $ git checkout develop

 $ git merge --no-ff fixbug-1.1.1

(4).移除本地和远程仓库的 fixbug-1.1.1

 $ git branch -d fixbug-1.1.1

 $ git push origin --delete fixbug-1.1.1

总结

啊哈,又到尾声了。上面的 Git 常用命令Git Flow 只是一些基本常识,并没有什么新的东西加入。在平时的团队协作中有些对于我自身而言还是比较新鲜的,比如 tag ,这些一般都交给老大来弄(因为他要 review):D 。好像跑偏了。。。对自己而言,理一遍后的收获还是不小的,对 Git Flow 的整个流程有了大概的了解,但具体每个 git 命令内部是怎么处理的呢,这个留到后面再梳理一下~

参考内容:



Git分支管理策略


A successful Git branching model

戳这里前往我的小屋 I'm Jony :-D

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

推荐阅读更多精彩内容

  • 多种多样的工作流使得在项目中实施Git时变得难以选择。这份教程提供了一个出发点,调查企业团队最常见的Git工作流。...
    JSErik阅读 4,311评论 2 8
  • Git分支管理 master:主分支,当前分支上的代码随时可以直接发布,并且只能通过Pull Request从其他...
    UEUEO阅读 9,465评论 5 34
  • 凡人下凡阅读 170评论 0 0
  • (节令咏) 文/菊 十五中秋赏月宫, 萤光闪烁舞飞虫; 嫦娥奔月矇眬影, 折桂飘香夜彩虹。 佳境良时观盛景, 云霞...
    斌之志阅读 1,772评论 34 41