Git rebase命令實戰
一、前言
一句話,git rebase 可以幫助專案中的提交歷史乾淨整潔!!!
二、避免合併出現分叉現象
git merge操作
1、新建一個 develop 分支
2、在develop分支上新建兩個檔案
3、然後分別執行 add、commit、push
4、接著切換到master分支
分別新增c.txt 和 d.txt兩個檔案,分別進行add、commit、push
5、現在想把develop分支上開發的部分合併到master分支上
6、git merge 會將master和develop合併的過程通過如下形式展示出來。
藉助 gitk 命令
藉助sourceTree工具
git rebase操作
如果master和develop分支上的這些開發部分都是同一個人操作,在合併的時候不想產生這種分叉的結果,怎麼辦呢?
git-rebase命令簡介:用在從上游分支獲取最新commit資訊,並有機的將當前分支和上游分支進行合併。因為develop分支是在master分支基礎上建立的,所以master稱為topic的上游分支。
1、首先通過 git reset 恢復到master合併之前的狀態
2、切換到develop分支,執行如下操作
3、如果你想把 rebase 之後的 master 分支推送到遠端倉庫,Git 會阻止你這麼做,因為兩個分支包含衝突。但你可以傳入 –force 標記來強行推送。
4、檢視一下develop分支合併的效果,如下。
看一下rebase的結果,就像是develop先把自己的提交儲存起來,然後將master中的提交合並過來,最後在加上自身分支的提交,這樣就不存在分支的合併效果了。
5、接著切換到master分支,執行git merge 操作就可以了
這時候,master和develop分支已經同步了。
其他異常情況
在rebase的過程中,也許會出現衝突(conflict). 在這種情況,Git會停止rebase並會讓你去解決 衝突;在解決完衝突後,用"git-add"命令去更新這些內容的索引(index),然後你無需執行 git-commit,只要執行 git rebase --continue。這樣git會繼續應用(apply)餘下的補丁。在任何時候,你可以用--abort引數來終止rebase的行動,並且"mywork" 分支會回到rebase開始前的狀態。即git rebase --abort。
手動合併多個commit記錄
rebase -i 命令介紹
git rebase -i [startpoint] [endpoint]
其中-i的意思是--interactive,即彈出互動式的介面讓使用者編輯完成合並操作,[startpoint] [endpoint]則指定了一個編輯區間,如果不指定[endpoint],則該區間的終點預設是當前分支HEAD所指向的commit(注:該區間指定的是一個前開後閉的區間)。
在檢視到了log日誌後,我們執行以下命令:
git rebase -i 0bb85c 582db9
或者
git rebase -i HEAD~3
上面未被註釋的部分列出的是我們本次rebase操作包含的所有提交,下面註釋部分是git為我們提供的命令說明。每一個commit id 前面的pick表示指令型別,git 為我們提供了以下幾個命令:
pick:保留該commit(縮寫:p)
reword:保留該commit,但我需要修改該commit的註釋(縮寫:r)
edit:保留該commit, 但我要停下來修改該提交(不僅僅修改註釋)(縮寫:e)
squash:將該commit和前一個commit合併(縮寫:s)
fixup:將該commit和前一個commit合併,但我不要保留該提交的註釋資訊(縮寫:f)
exec:執行shell命令(縮寫:x)
drop:我要丟棄該commit(縮寫:d)
rebase -i命令執行
1、git rebase -i HEAD~3
2、編輯合併資訊
3、修改commit資訊
4、commit資訊預覽
5、commit合併結果
6、可以看到master上之後又1條提交記錄了,而develop上還有3個提交記錄
還是要通過 git push -f 命令將合併的commit結果提交的遠端倉庫中。
如果develop分支也想要變成master分支這種合併效果,記住不要使用git merge 命令,還時會出現分叉的情況。 繼續使用 git rebase master命令 。
自動合併多個commit記錄
命令介紹
git commit –fixup 自動在commit訊息前新增fixup!關鍵字。
git rebase -i –autosquash 使用rebase自動合併被標記為fixup!的commit,其實是根據sha值來的。
命令操作
1.繼續修復如下圖所示對應的bug
2、修改完之後執行 git commit --fixup 需要合併的commit id
3、commit fixup 之後的效果
4、執行git rebase -i --autosquash
或者 git rebase -i --autosquash 需要合併commit id的父級commit id
5、執行rebase autosquash結果