Git Flow 的概念
??在使用Git的過程中如果沒有清晰流程和規(guī)劃,否則,每個(gè)人都提交一堆雜亂無(wú)章的commit,項(xiàng)目很快就會(huì)變得難以協(xié)調(diào)和維護(hù)。
Git版本管理同樣需要一個(gè)清晰的流程和規(guī)范垂蜗。
Vincent Driessen 為了解決這個(gè)問題提出了 A Successful Git Branching Model
以下是基于Vincent Driessen提出的Git Flow 流程圖
Git Flow 的常用分支
-
Production 分支
也就是我們經(jīng)常使用的Master分支豌鸡,這個(gè)分支最近發(fā)布到生產(chǎn)環(huán)境的代碼,最近發(fā)布的Release, 這個(gè)分支只能從其他分支合并,不能在這個(gè)分支直接修改
-
Develop 分支
這個(gè)分支是我們是我們的主開發(fā)分支,包含所有要發(fā)布到下一個(gè)Release的代碼姻采,這個(gè)主要合并與其他分支,比如Feature分支
-
Feature 分支
這個(gè)分支主要是用來(lái)開發(fā)一個(gè)新的功能题涨,一旦開發(fā)完成偎谁,我們合并回Develop分支進(jìn)入下一個(gè)Release
-
Release分支
當(dāng)你需要一個(gè)發(fā)布一個(gè)新Release的時(shí)候总滩,我們基于Develop分支創(chuàng)建一個(gè)Release分支,完成Release后巡雨,我們合并到Master和Develop分支
-
Hotfix分支
當(dāng)我們?cè)赑roduction發(fā)現(xiàn)新的Bug時(shí)候闰渔,我們需要?jiǎng)?chuàng)建一個(gè)Hotfix, 完成Hotfix后,我們合并回Master和Develop分支铐望,所以Hotfix的改動(dòng)會(huì)進(jìn)入下一個(gè)Release
Git Flow 如何使用
-
Master/Devlop 分支
所有在Master分支上的Commit應(yīng)該打上Tag冈涧,一般情況下Master不存在Commit,Devlop分支基于Master分支創(chuàng)建
-
Feature 分支
Feature分支做完后正蛙,必須合并回Develop分支, 合并完分支后一般會(huì)刪點(diǎn)這個(gè)Feature分支督弓,畢竟保留下來(lái)意義也不大。
-
Release 分支
Release分支基于Develop分支創(chuàng)建乒验,打完Release分支之后愚隧,我們可以在這個(gè)Release分支上測(cè)試,修改Bug等锻全。同時(shí)狂塘,其它開發(fā)人員可以基于Develop分支新建Feature (記住:一旦打了Release分支之后不要從Develop分支上合并新的改動(dòng)到Release分支)發(fā)布Release分支時(shí)鳄厌,合并Release到Master和Develop荞胡, 同時(shí)在Master分支上打個(gè)Tag記住Release版本號(hào),然后可以刪除Release分支了了嚎。
-
Hotfix 分支
hotfix分支基于Master分支創(chuàng)建泪漂,開發(fā)完后需要合并回Master和Develop分支,同時(shí)在Master上打一個(gè)tag歪泳。
Git Flow 命令示例
創(chuàng)建 Devlop
git branch develop
git push -u origin develop
開始 Feature
# 通過develop新建feaeure分支
git checkout -b feature develop
# 或者, 推送至遠(yuǎn)程服務(wù)器:
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
# 如果需要?jiǎng)h除遠(yuǎn)程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ī)劃纵刘,那么強(qiáng)烈推薦使用Vincent Driessen 提出的GIt flow
讓你的代碼管理騷起來(lái)邀窃。
結(jié)尾
本站文章圖片等等來(lái)源于網(wǎng)絡(luò),僅作為學(xué)習(xí)之用,版權(quán)歸原作者所有.如果侵犯了您的權(quán)益,請(qǐng)來(lái)信告知,我會(huì)盡快刪除.