開發(fā)經(jīng)驗(yàn)漫談 -- Git在開發(fā)流程中的運(yùn)用

這幾期和大家分享下我自己在開發(fā)時(shí)的一些經(jīng)驗(yàn),這次來說說關(guān)于Git在開發(fā)流程中的運(yùn)用把鉴。

目的

  1. 保持提交歷史整潔仆潮,俗稱的一條線提交宏蛉。
  2. 讓項(xiàng)目代碼有跡可循,提供清晰的開發(fā)歷程性置,亦稱:取其精華檐晕,去其糟粕。
  3. 幫助大家養(yǎng)成好的代碼開發(fā)習(xí)慣蚌讼,即:如何更好地和他人合作辟灰。
  4. 提供一個(gè)思路,讓大家更深刻的理解git篡石。

請(qǐng)先花時(shí)間閱讀

  1. 如果你沒有接觸過git芥喇,請(qǐng)先閱讀:http://git-scm.com/book/zh/v2
  2. 必讀:https://www.atlassian.com/git/tutorials/merging-vs-rebasing

示例系統(tǒng)

我們使用一個(gè)簡單的項(xiàng)目作為示例來進(jìn)行說明。

sys.png

該系統(tǒng)由用戶管理模塊和角色管理模塊組成凰萨,該項(xiàng)目已經(jīng)完成了角色模塊的開發(fā)继控,現(xiàn)在在開發(fā)用戶模塊。

開發(fā)流程

第一步:獲取項(xiàng)目代碼

ligang@vm-xubuntu ~/devspace $ git clone /home/ligang/repository/gitflow.git
Cloning into gitflow...
remote: Counting objects: 6, done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 6 (delta 0), reused 0 (delta 0)
Receiving objects: 100% (6/6), done.

當(dāng)前的提交歷史如下:

init.png

創(chuàng)建遠(yuǎn)程合作分支

我們把這個(gè)分支命名為user_admin

ligang@vm-xubuntu ~/devspace/gitflow $ git push -u origin user_admin
Total 0 (delta 0), reused 0 (delta 0)
To /home/ligang/repository/gitflow.git
 * [new branch]      user_admin -> user_admin
Branch user_admin set up to track remote branch user_admin from origin.

操作完成后胖眷,提交歷史如下:

user_admin_init.png

說明:合作開發(fā)user_admin模塊的同學(xué)武通,會(huì)在這個(gè)分支上合并彼此的代碼。

第三步:創(chuàng)建個(gè)人分支(真正的開發(fā)工作在這里進(jìn)行)

我們把這個(gè)分支命名為:user_admin_ligang

ligang@vm-xubuntu ~/devspace/gitflow $ git push -u origin user_admin_ligang
Total 0 (delta 0), reused 0 (delta 0)
To /home/ligang/repository/gitflow.git
 * [new branch]      user_admin_ligang -> user_admin_ligang
Branch user_admin_ligang set up to track remote branch user_admin_ligang from origin.
user_admin_ligang_init.png

請(qǐng)注意:

  1. 此分支是在遠(yuǎn)程合作分支(user_admin)的基礎(chǔ)上創(chuàng)建的珊搀。
  2. 此分支只可合并遠(yuǎn)程合作分支冶忱,不可以直接合并master。

分支合并流程

假設(shè)在user_admin_ligang的個(gè)人分支中已經(jīng)完成了開發(fā)境析,現(xiàn)在需要把這部分代碼提交給被人使用囚枪,那么請(qǐng)按照如下方式操作:

假設(shè)開發(fā)完成后的提交歷史如下:

user_admin_ligang_before_rebase.png

第一步:整理個(gè)人開發(fā)分支中待合并的提交,去掉無用的劳淆,僅保留有用的

  • 切到user_admin_ligang分支
ligang@vm-xubuntu  ~/devspace/gitflow $ git checkout user_admin_ligang
ligang@vm-xubuntu  ~/devspace/gitflow $ git branch
  master
  user_admin
* user_admin_ligang
ligang@vm-xubuntu  ~/devspace/gitflow $
  • 查找newbase

在這個(gè)清理過程中链沼,我需要清理掉tmp1和tmp2這2個(gè)臨時(shí)提交,所以newbase就是init沛鸵,這里獲得它的版本號(hào):

find_newbase.png
  • 執(zhí)行清理

這一步是不可逆的括勺,請(qǐng)謹(jǐn)慎操作,亦可先備份。

user_admin_ligang_rebase_i.png

這里按照提示疾捍,我們編輯rebase信息:

user_admin_ligang_rebase_edit.png

保存退出奈辰,由于上面我們告訴rebase我們要重新編輯提交信息(r,reword),這里會(huì)進(jìn)入提交信息編輯界面拾氓,我們修改最終提交信息如下:

user_admin_ligang_rebase_reword.png

保存退出冯挎,清理過程結(jié)束底哥,這里再次查看提交歷史:

user_admin_ligang_rebase_done.png

這里可以看到咙鞍,tmp1和tmp2已經(jīng)被清理掉了,最終的done2是一個(gè)全新的提交趾徽。

第二步:合并個(gè)人分支到遠(yuǎn)程合作分支

請(qǐng)確保此時(shí)只有你一個(gè)人操作遠(yuǎn)程合作分支

  • 更新本地遠(yuǎn)程合作分支到最新
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout user_admin
Switched to branch 'user_admin'
ligang@vm-xubuntu ~/devspace/gitflow $ git pull origin user_admin
From /home/ligang/repository/gitflow
 * branch            user_admin -> FETCH_HEAD
Already up to date.
  • 切到user_admin_ligang分支
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout user_admin_ligang
Switched to branch 'user_admin_ligang'
  • 衍合個(gè)人開發(fā)分支

衍合前

user_admin_before_rebase.png

衍合

ligang@vm-xubuntu ~/devspace/gitflow $ git rebase user_admin
First, rewinding head to replay your work on top of it...
Applying: done2
Using index info to reconstruct a base tree...
M   show.txt
Falling back to patching base and 3-way merge...
Auto-merging show.txt
CONFLICT (content): Merge conflict in show.txt
error: Failed to merge in the changes.
Patch failed at 0001 done2
Use 'git am --show-current-patch' to see the failed patch

Resolve all conflicts manually, mark them as resolved with
"git add/rm <conflicted_files>", then run "git rebase --continue".
You can instead skip this commit: run "git rebase --skip".
To abort and get back to the state before "git rebase", run "git rebase --abort".

這里有可能需要解決沖突续滋,再continue完成整個(gè)衍合過程。

衍合后

user_admin_after_rebase.png
  • 合并入遠(yuǎn)程合作分支
ligang@vm-xubuntu ~/devspace/gitflow $ git merge user_admin_ligang
Updating add0d89..9ed757b
Fast-forward
 show.txt | 1 +
 1 file changed, 1 insertion(+)

合并后的提交歷史

user_admin_merge.png

刪除個(gè)人開發(fā)分支

ligang@vm-xubuntu ~/devspace/gitflow $ git branch -d user_admin_ligang
Deleted branch user_admin_ligang (was 9ed757b).
ligang@vm-xubuntu ~/devspace/gitflow $ git push origin :user_admin_ligang
To /home/ligang/repository/gitflow.git
 - [deleted]         user_admin_ligang

合并到主干

操作前確認(rèn)

進(jìn)行這一步操作前孵奶,請(qǐng)確認(rèn)已經(jīng)滿足如下條件:

  1. 請(qǐng)確認(rèn)待合并的遠(yuǎn)程合作分支上的開發(fā)目標(biāo)已全部完成疲酌。
  2. 請(qǐng)確認(rèn)即將把代碼合并入主干進(jìn)行發(fā)布上線。

如不能全部滿足上述所有條件了袁,請(qǐng)不要進(jìn)行此操作朗恳。

合并入主干

請(qǐng)確保此時(shí)只有你一個(gè)人操作遠(yuǎn)程分支及主干

  • 更新本地主干到最新
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout master
Switched to branch 'master'
Your branch is up to date with 'origin/master'.
ligang@vm-xubuntu ~/devspace/gitflow $ git pull
Already up to date.
  • 切到user_admin分支
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout user_admin
Switched to branch 'user_admin'
  • 衍合遠(yuǎn)程合作分支
ligang@vm-xubuntu ~/devspace/gitflow $ git rebase master
Current branch user_admin is up to date.

這里的過程和遠(yuǎn)程合作分支衍合時(shí)是一樣的,有可能需要解決沖突载绿,再continue完成整個(gè)衍合過程粥诫。

  • 合并入主干
ligang@vm-xubuntu ~/devspace/gitflow $ git checkout master
Switched to branch 'master'
Your branch is up to date with 'origin/master'.
ligang@vm-xubuntu ~/devspace/gitflow $ git merge user_admin
Updating 73180c1..9ed757b
Fast-forward
 show.txt | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)
  • 刪除遠(yuǎn)程合作分支
ligang@vm-xubuntu ~/devspace/gitflow $ git branch -d user_admin
Deleted branch user_admin (was 9ed757b).
ligang@vm-xubuntu ~/devspace/gitflow $ git push origin :user_admin
To /home/ligang/repository/gitflow.git
 - [deleted]         user_admin

最終的提交歷史

final.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市崭庸,隨后出現(xiàn)的幾起案子怀浆,更是在濱河造成了極大的恐慌,老刑警劉巖怕享,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件执赡,死亡現(xiàn)場離奇詭異,居然都是意外死亡函筋,警方通過查閱死者的電腦和手機(jī)沙合,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來跌帐,“玉大人灌诅,你說我怎么就攤上這事『” “怎么了猜拾?”我有些...
    開封第一講書人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長佣盒。 經(jīng)常有香客問我挎袜,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任盯仪,我火速辦了婚禮紊搪,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘全景。我一直安慰自己耀石,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開白布爸黄。 她就那樣靜靜地躺著滞伟,像睡著了一般。 火紅的嫁衣襯著肌膚如雪炕贵。 梳的紋絲不亂的頭發(fā)上梆奈,一...
    開封第一講書人閱讀 51,365評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音称开,去河邊找鬼亩钟。 笑死,一個(gè)胖子當(dāng)著我的面吹牛鳖轰,可吹牛的內(nèi)容都是我干的清酥。 我是一名探鬼主播,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蕴侣,長吁一口氣:“原來是場噩夢啊……” “哼焰轻!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起睛蛛,我...
    開封第一講書人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤鹦马,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后忆肾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體荸频,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年客冈,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了旭从。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡场仲,死狀恐怖和悦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情渠缕,我是刑警寧澤鸽素,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站亦鳞,受9級(jí)特大地震影響馍忽,放射性物質(zhì)發(fā)生泄漏棒坏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一遭笋、第九天 我趴在偏房一處隱蔽的房頂上張望坝冕。 院中可真熱鬧,春花似錦瓦呼、人聲如沸喂窟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽磨澡。三九已至,卻和暖如春蹋辅,著一層夾襖步出監(jiān)牢的瞬間钱贯,已是汗流浹背挫掏。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來泰國打工侦另, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人尉共。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓褒傅,卻偏偏與公主長得像,于是被迫代替她去往敵國和親袄友。 傳聞我的和親對(duì)象是個(gè)殘疾皇子殿托,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 電影開始時(shí),映入眼簾的是一派美好的自然風(fēng)光剧蚣。峰巒疊翠的崇山峻嶺支竹、綠油油的青草地、蔚藍(lán)的天空與清澈的湖水相互交織鸠按,...
    辛迪在安菲爾德閱讀 1,254評(píng)論 0 3