天天看點

Git Flow 正确使用姿勢

Git Flow 的概念

  在使用Git的過程中如果沒有清晰流程和規劃,否則,每個人都送出一堆雜亂無章的commit,項目很快就會變得難以協調和維護。

Git版本管理同樣需要一個清晰的流程和規範。

Vincent Driessen 為了解決這個問題提出了 ​​​A Successful Git Branching Model​​ 以下是基于Vincent Driessen提出的Git Flow 流程圖

Git Flow 正确使用姿勢

Git Flow 的常用分支

Production 分支

也就是我們經常使用的Master分支,這個分支最近釋出到生産環境的代碼,最近釋出的Release, 這個分支隻能從其他分支合并,不能在這個分支直接修改

Develop 分支

這個分支是我們是我們的主開發分支,包含所有要釋出到下一個Release的代碼,這個主要合并與其他分支,比如Feature分支

Feature 分支

這個分支主要是用來開發一個新的功能,一旦開發完成,我們合并回Develop分支進入下一個Release

Release分支

當你需要一個釋出一個新Release的時候,我們基于Develop分支建立一個Release分支,完成Release後,我們合并到Master和Develop分支

Hotfix分支

當我們在Production發現新的Bug時候,我們需要建立一個Hotfix, 完成Hotfix後,我們合并回Master和Develop分支,是以Hotfix的改動會進入下一個Release

Git Flow 如何使用

Master/Devlop 分支

所有在Master分支上的Commit應該打上Tag,一般情況下Master不存在Commit,Devlop分支基于Master分支建立

Git Flow 正确使用姿勢

Feature 分支

Feature分支做完後,必須合并回Develop分支, 合并完分支後一般會删點這個Feature分支,畢竟保留下來意義也不大。

Git Flow 正确使用姿勢

Release 分支

Release分支基于Develop分支建立,打完Release分支之後,我們可以在這個Release分支上測試,修改Bug等。同時,其它開發人員可以基于Develop分支建立Feature (記住:一旦打了Release分支之後不要從Develop分支上合并新的改動到Release分支)釋出Release分支時,合并Release到Master和Develop, 同時在Master分支上打個Tag記住Release版本号,然後可以删除Release分支了。

Git Flow 正确使用姿勢

Hotfix 分支

hotfix分支基于Master分支建立,開發完後需要合并回Master和Develop分支,同時在Master上打一個tag。

Git Flow 指令示例

建立 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      

使用建議