前言
Git幫助我們更好地版本控制亭病,團(tuán)隊(duì)協(xié)作過程中我們需要一套嚴(yán)謹(jǐn)?shù)腉it 操作流程規(guī)范來保證面對(duì)各種情況能保證代碼的版本控制,不能為了一時(shí)偷懶隨性提交鹅很、合并代碼。隨意提交罪帖、合并代碼很有可能導(dǎo)致代碼丟失促煮、混亂一系列不可挽回的后果。本文是相關(guān)一套Git流程操作整袁,能幫助我們更好地進(jìn)行代碼管理菠齿。其中有什么需要改進(jìn)的地方,我們一起來溝通優(yōu)化坐昙。
正文
一绳匀、分支介紹
master
: 主分支,常駐分支,master代碼與線上代碼保持一致疾棵,只能合并“developer"分支中的代碼戈钢,不能直接操作,也不能合并其他分支是尔。
developer
: 開發(fā)主分支殉了,常駐分支, 代碼上線后合并到"master"分支。
fix
: 修復(fù)分支拟枚,開發(fā)完畢需要?jiǎng)h除薪铜,用于不在版本計(jì)劃中的bug修復(fù)。
dev_x_x_x
:版本開發(fā)分支恩溅,開發(fā)完畢需要?jiǎng)h除隔箍,根據(jù)版本計(jì)劃進(jìn)行開始的分支,可多版本分支并行開發(fā)脚乡。
feature
:功能開發(fā)分支蜒滩,開發(fā)完畢需要?jiǎng)h除,同個(gè)版本中多個(gè)模塊進(jìn)行開發(fā)時(shí)每窖,可從"dev_x_x_x"分支中拉出多個(gè)"feature",對(duì)應(yīng)相應(yīng)的模塊進(jìn)行并行開發(fā)帮掉。
二、開發(fā)流程
可以參照上面的流程圖:
1窒典、master
-> ```developer`` 分支
如果沒有developer
分支,從master
拉出一個(gè)developer
分支稽莉。
2瀑志、developer
-> dev_x_x_x
分支
從developer
分支開出一個(gè)與版本需求對(duì)應(yīng)的dev_x_x_x
分支,開發(fā)完成后合并回developer
分支污秆,可以多個(gè)版本進(jìn)行并行開發(fā)劈猪。
3、dev_x_x_x
->feature
分支
建議根據(jù)版本需求中的每個(gè)功能點(diǎn)良拼,從dev_x_x_x
分支拉出相對(duì)應(yīng)的feature
分支战得,開發(fā)完成后合并回dev_x_x_x
分支。這樣可以更加靈活地應(yīng)對(duì)各種情況庸推,例如: 開發(fā)過程中常侦,項(xiàng)目需要提前上線,砍掉一些功能點(diǎn)贬媒,這個(gè)時(shí)候可以只合并需要的功能點(diǎn)聋亡。
4、fix
分支修復(fù)bug
如果是需要發(fā)布一個(gè)緊急版本修復(fù)線上bug际乘,從developer
分支直接拉出一個(gè)fix
分支進(jìn)行修復(fù)坡倔,修復(fù)完畢后將需要將fix
合并到developer
分支后還需將developer
分支合并進(jìn)```dev_x_x_x``分支,保持開發(fā)分支的代碼同步;
如果是非緊急bug,可以跟隨正在開發(fā)的版本發(fā)布罪塔,從dev_x_x_x
分支拉出一個(gè)fix
分支投蝉,與``feature```分支并行。
三征堪、合并時(shí)間點(diǎn)
1瘩缆、功能點(diǎn)自測(cè)完畢
feature
分支和非緊急修復(fù)fix
分支,在開發(fā)人員自測(cè)完后合并到dev_x_x_x
分支请契;
2咳榜、提測(cè)
版本提測(cè)的時(shí)候,將dev_x_x_x
分支所對(duì)應(yīng)的所有feature
分支和fix
分支合并回dev_x_x_x
分支后爽锥,將dev_x_x_x
分支代碼打包提測(cè)涌韩。
3、測(cè)試過程中
提測(cè)后氯夷,測(cè)試人員測(cè)試過程中臣樱,發(fā)現(xiàn)bug需要修復(fù),從dev_x_x_x
分支上開出fix
分支修復(fù)bug腮考,修復(fù)完合并回dev_x_x_x
分支雇毫。
如果期間有緊急fix
分支合并到developer
分支,需要將developer
分支合并進(jìn)dev_x_x_x
分支進(jìn)行測(cè)試踩蔚。
4棚放、測(cè)試完畢
dev_x_x_x
分支測(cè)試完畢封包后,將dev_x_x_x
合并回developer
分支馅闽,將developer
分支打包準(zhǔn)備上線飘蚯,封包后有改動(dòng)走緊急"fix"分支。
5福也、正式上線后
版本正式上線后將developer
分支合并到master
上局骤。
四、注意點(diǎn)
1暴凑、除了master
分支和developer
分支保持不刪之外峦甩,其他相關(guān)分支開發(fā)完畢應(yīng)及時(shí)刪除避免造成開發(fā)分支數(shù)量過多帶來管理混亂。
2现喳、master
分支的修改只能從developer
分支合并凯傲,不能直接進(jìn)行操作,或者從其他分支合并拿穴。
3泣洞、緊急fix
分支合并到developer
分支后,需要將developer
分支合并進(jìn)dev_x_x_x
分支