Git Flow 的正確使用姿勢

Git Flow 的概念

https://www.cnblogs.com/cnblogsfans/p/5075073.html

在使用Git的過程中如果沒有清晰流程和規(guī)劃墓拜,否則,每個人都提交一堆雜亂無章的commit,項目很快就會變得難以協(xié)調和維護撮弧。
Git版本管理同樣需要一個清晰的流程和規(guī)范姚糊。
Vincent Driessen 為了解決這個問題提出了 A Successful Git Branching Model
以下是基于Vincent Driessen提出的Git Flow 流程圖

image

Git Flow 的常用分支

  • Production 分支

也就是我們經(jīng)常使用的Master分支救恨,這個分支最近發(fā)布到生產(chǎn)環(huán)境的代碼,最近發(fā)布的Release擎淤, 這個分支只能從其他分支合并秸仙,不能在這個分支直接修改

  • Develop 分支

這個分支是我們是我們的主開發(fā)分支,包含所有要發(fā)布到下一個Release的代碼席吴,這個主要合并與其他分支,比如Feature分支

  • Feature 分支

這個分支主要是用來開發(fā)一個新的功能柬姚,一旦開發(fā)完成庄涡,我們合并回Develop分支進入下一個Release

  • Release分支

當你需要一個發(fā)布一個新Release的時候穴店,我們基于Develop分支創(chuàng)建一個Release分支撕捍,完成Release后,我們合并到Master和Develop分支

  • Hotfix分支

當我們在Production發(fā)現(xiàn)新的Bug時候泣洞,我們需要創(chuàng)建一個Hotfix, 完成Hotfix后卦洽,我們合并回Master和Develop分支,所以Hotfix的改動會進入下一個Release

Git Flow 如何使用

  • Master/Devlop 分支

所有在Master分支上的Commit應該打上Tag斜棚,一般情況下Master不存在Commit阀蒂,Devlop分支基于Master分支創(chuàng)建

image
  • Feature 分支

Feature分支做完后,必須合并回Develop分支, 合并完分支后一般會刪點這個Feature分支弟蚀,畢竟保留下來意義也不大蚤霞。

image
  • Release 分支

Release分支基于Develop分支創(chuàng)建,打完Release分支之后义钉,我們可以在這個Release分支上測試,修改Bug等捶闸。同時夜畴,其它開發(fā)人員可以基于Develop分支新建Feature (記住:一旦打了Release分支之后不要從Develop分支上合并新的改動到Release分支)發(fā)布Release分支時删壮,合并Release到Master和Develop贪绘, 同時在Master分支上打個Tag記住Release版本號,然后可以刪除Release分支了央碟。

image
  • Hotfix 分支

hotfix分支基于Master分支創(chuàng)建税灌,開發(fā)完后需要合并回Master和Develop分支,同時在Master上打一個tag亿虽。

image

Git Flow 命令示例

創(chuàng)建 Devlop

git branch develop  
git push -u origin develop

開始 Feature

# 通過develop新建feaeure分支
git checkout -b feature develop
# 或者, 推送至遠程服務器:
git push -u origin feature    

# 修改md文件   
git status
git add .
git commit    

完成 Feature

git pull origin develop
git checkout develop 

#--no-ff:不使用fast-forward方式合并菱涤,保留分支的commit歷史
#--squash:使用squash方式合并,把多次分支commit歷史壓縮為一次

git merge --no-ff feature
git push origin develop

git branch -d some-feature

# 如果需要刪除遠程feature分支:
git push origin --delete feature   

開始 Release

git checkout -b release-0.1.0 develop

完成 Release

git checkout master
git merge --no-ff release-0.1.0
git push

git checkout develop
git merge --no-ff release-0.1.0
git push

git branch -d release-0.1.0
git push origin --delete release-0.1.0   

# 合并master/devlop分支之后洛勉,打上tag 
git tag -a v0.1.0 master
git push --tags

開始 Hotfix

git checkout -b hotfix-0.1.1 master  

完成 Hotfix

git checkout master
git merge --no-ff hotfix-0.1.1
git push

git checkout develop
git merge --no-ff hotfix-0.1.1
git push

git branch -d hotfix-0.1.1
git push origin --delete  hotfix-0.1.1 

git tag -a v0.1.1 master
git push --tags

使用建議

如果你的代碼沒有清晰流程和規(guī)劃粘秆,那么強烈推薦使用Vincent Driessen 提出的GIt flow
讓你的代碼管理騷起來。

結尾

本站文章圖片等等來源于網(wǎng)絡,僅作為學習之用,版權歸原作者所有.如果侵犯了您的權益,請來信告知,我會盡快刪除.

作者:qingwenLi
鏈接:http://www.reibang.com/p/41910dc6ef29
來源:簡書
著作權歸作者所有收毫。商業(yè)轉載請聯(lián)系作者獲得授權攻走,非商業(yè)轉載請注明出處氓涣。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市陋气,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌引润,老刑警劉巖巩趁,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異淳附,居然都是意外死亡议慰,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門奴曙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來别凹,“玉大人,你說我怎么就攤上這事洽糟÷疲” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵坤溃,是天一觀的道長拍霜。 經(jīng)常有香客問我,道長薪介,這世上最難降的妖魔是什么祠饺? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮汁政,結果婚禮上道偷,老公的妹妹穿的比我還像新娘。我一直安慰自己记劈,他們只是感情好勺鸦,可當我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著目木,像睡著了一般祝旷。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上嘶窄,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天怀跛,我揣著相機與錄音,去河邊找鬼柄冲。 笑死吻谋,一個胖子當著我的面吹牛,可吹牛的內容都是我干的现横。 我是一名探鬼主播漓拾,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼阁最,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了骇两?” 一聲冷哼從身側響起速种,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎低千,沒想到半個月后配阵,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡示血,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年棋傍,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片难审。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡瘫拣,死狀恐怖,靈堂內的尸體忽然破棺而出告喊,到底是詐尸還是另有隱情麸拄,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布黔姜,位于F島的核電站感帅,受9級特大地震影響,放射性物質發(fā)生泄漏地淀。R本人自食惡果不足惜失球,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望帮毁。 院中可真熱鬧实苞,春花似錦、人聲如沸烈疚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽爷肝。三九已至猾浦,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間灯抛,已是汗流浹背金赦。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留对嚼,地道東北人夹抗。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像纵竖,于是被迫代替她去往敵國和親漠烧。 傳聞我的和親對象是個殘疾皇子杏愤,可洞房花燭夜當晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內容