Git版本控制管理

目的

規(guī)范版本管理,在開發(fā)過程中不影響新版本的發(fā)布、緊急問題修復(fù)

Git總體結(jié)構(gòu).png

Git常用分支

Production 分支

也就是我們經(jīng)常使用的Master分支,這個(gè)分支最近發(fā)布到生產(chǎn)環(huán)境的代碼,最近發(fā)布的Release, 這個(gè)分支只能從其他分支合并,不能在這個(gè)分支直接修改
所有在Master分支上的Commit應(yīng)該打上Tag,一般情況下Master不存在Commit

Production/Master 分支.png

Develop 分支

這個(gè)分支是我們是我們的主開發(fā)分支,包含所有要發(fā)布到下一個(gè)Release的代碼,這個(gè)主要合并與其他分支,比如Feature分支
Devlop分支基于Master分支創(chuàng)建

Develop 分支.png

Feature 分支

這個(gè)分支主要是用來開發(fā)一個(gè)新的功能,一旦開發(fā)完成,我們合并回Develop分支進(jìn)入下一個(gè)Release
Feature分支做完后,必須合并回Develop分支, 合并完分支后一般會(huì)刪點(diǎn)這個(gè)Feature分支,畢竟保留下來意義也不大。

Feature 分支4.png

Release分支

當(dāng)你需要一個(gè)發(fā)布一個(gè)新Release的時(shí)候,我們基于Develop分支創(chuàng)建一個(gè)Release分支,完成Release后,我們合并到Master和Develop分支
Release分支基于Develop分支創(chuàng)建,打完Release分支之后,我們可以在這個(gè)Release分支上測(cè)試,修改Bug等。同時(shí),其它開發(fā)人員可以基于Develop分支新建Feature (記?。阂坏┐蛄薘elease分支之后不要從Develop分支上合并新的改動(dòng)到Release分支)發(fā)布Release分支時(shí),合并Release到Master和Develop, 同時(shí)在Master分支上打個(gè)Tag記住Release版本號(hào),然后可以刪除Release分支了。

Release分支.png

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
hotfix分支基于Master分支創(chuàng)建,開發(fā)完后需要合并回Master和Develop分支,同時(shí)在Master上打一個(gè)tag。

Hotfix分支.png

Git命令示例

開始 Feature

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

完成 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

我是愛超越的歡,本文為原創(chuàng),如轉(zhuǎn)載請(qǐng)請(qǐng)注明出處。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容