溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何使用Git rebase命令

發(fā)布時(shí)間:2020-07-27 09:23:01 來(lái)源:億速云 閱讀:243 作者:小豬 欄目:開(kāi)發(fā)技術(shù)

小編這次要給大家分享的是如何使用Git rebase命令,文章內(nèi)容豐富,感興趣的小伙伴可以來(lái)了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

一、前言

  一句話,git rebase 可以幫助項(xiàng)目中的提交歷史干凈整潔?。。?/p>

二、避免合并出現(xiàn)分叉現(xiàn)象git merge操作

  1、新建一個(gè) develop 分支

  如何使用Git rebase命令

  2、在develop分支上新建兩個(gè)文件

如何使用Git rebase命令

  3、然后分別執(zhí)行 add、commit、push

如何使用Git rebase命令

  4、接著切換到master分支

  分別添加c.txt 和 d.txt兩個(gè)文件,分別進(jìn)行add、commit、push

如何使用Git rebase命令

  5、現(xiàn)在想把develop分支上開(kāi)發(fā)的部分合并到master分支上

如何使用Git rebase命令

  6、git merge 會(huì)將master和develop合并的過(guò)程通過(guò)如下形式展示出來(lái)。

  借助 gitk 命令

如何使用Git rebase命令

  借助sourceTree工具

如何使用Git rebase命令

git rebase操作

  如果master和develop分支上的這些開(kāi)發(fā)部分都是同一個(gè)人操作,在合并的時(shí)候不想產(chǎn)生這種分叉的結(jié)果,怎么辦呢?

  git-rebase命令簡(jiǎn)介:用在從上游分支獲取最新commit信息,并有機(jī)的將當(dāng)前分支和上游分支進(jìn)行合并。因?yàn)閐evelop分支是在master分支基礎(chǔ)上建立的,所以master稱為topic的上游分支。

  1、首先通過(guò) git reset 恢復(fù)到master合并之前的狀態(tài)

  2、切換到develop分支,執(zhí)行如下操作

如何使用Git rebase命令

如何使用Git rebase命令

  3、如果你想把 rebase 之后的 master 分支推送到遠(yuǎn)程倉(cāng)庫(kù),Git 會(huì)阻止你這么做,因?yàn)閮蓚€(gè)分支包含沖突。但你可以傳入 –force 標(biāo)記來(lái)強(qiáng)行推送。

如何使用Git rebase命令

  4、查看一下develop分支合并的效果,如下。

如何使用Git rebase命令

如何使用Git rebase命令

  看一下rebase的結(jié)果,就像是develop先把自己的提交保存起來(lái),然后將master中的提交合并過(guò)來(lái),最后在加上自身分支的提交,這樣就不存在分支的合并效果了。

  5、接著切換到master分支,執(zhí)行g(shù)it merge 操作就可以了

如何使用Git rebase命令

如何使用Git rebase命令

  這時(shí)候,master和develop分支已經(jīng)同步了。

其他異常情況

  在rebase的過(guò)程中,也許會(huì)出現(xiàn)沖突(conflict). 在這種情況,Git會(huì)停止rebase并會(huì)讓你去解決 沖突;在解決完沖突后,用"git-add"命令去更新這些內(nèi)容的索引(index),然后你無(wú)需執(zhí)行 git-commit,只要執(zhí)行 git rebase --continue。這樣git會(huì)繼續(xù)應(yīng)用(apply)余下的補(bǔ)丁。在任何時(shí)候,你可以用--abort參數(shù)來(lái)終止rebase的行動(dòng),并且"mywork" 分支會(huì)回到rebase開(kāi)始前的狀態(tài)。即git rebase --abort。

手動(dòng)合并多個(gè)commit記錄

rebase -i 命令介紹

git rebase -i [startpoint] [endpoint]

  其中-i的意思是--interactive,即彈出交互式的界面讓用戶編輯完成合并操作,[startpoint] [endpoint]則指定了一個(gè)編輯區(qū)間,如果不指定[endpoint],則該區(qū)間的終點(diǎn)默認(rèn)是當(dāng)前分支HEAD所指向的commit(注:該區(qū)間指定的是一個(gè)前開(kāi)后閉的區(qū)間)。

在查看到了log日志后,我們運(yùn)行以下命令:

git rebase -i 0bb85c 582db9

或者

git rebase -i HEAD~3
 

如何使用Git rebase命令

  上面未被注釋的部分列出的是我們本次rebase操作包含的所有提交,下面注釋部分是git為我們提供的命令說(shuō)明。每一個(gè)commit id 前面的pick表示指令類型,git 為我們提供了以下幾個(gè)命令:

  pick:保留該commit(縮寫(xiě):p)
  reword:保留該commit,但我需要修改該commit的注釋(縮寫(xiě):r)
  edit:保留該commit, 但我要停下來(lái)修改該提交(不僅僅修改注釋)(縮寫(xiě):e)
  squash:將該commit和前一個(gè)commit合并(縮寫(xiě):s)
  fixup:將該commit和前一個(gè)commit合并,但我不要保留該提交的注釋信息(縮寫(xiě):f)
  exec:執(zhí)行shell命令(縮寫(xiě):x)
  drop:我要丟棄該commit(縮寫(xiě):d)

rebase -i命令執(zhí)行

  1、git rebase -i HEAD~3

  2、編輯合并信息

如何使用Git rebase命令

  3、修改commit信息

如何使用Git rebase命令

  4、commit信息預(yù)覽

如何使用Git rebase命令

  5、commit合并結(jié)果

如何使用Git rebase命令

  6、可以看到master上之后又1條提交記錄了,而develop上還有3個(gè)提交記錄

如何使用Git rebase命令

  還是要通過(guò) git push -f 命令將合并的commit結(jié)果提交的遠(yuǎn)程倉(cāng)庫(kù)中。

  如果develop分支也想要變成master分支這種合并效果,記住不要使用git merge 命令,還時(shí)會(huì)出現(xiàn)分叉的情況。繼續(xù)使用 git rebase master命令。

如何使用Git rebase命令

自動(dòng)合并多個(gè)commit記錄

命令介紹

  git commit –fixup 自動(dòng)在commit消息前添加fixup!關(guān)鍵字。

  git rebase -i –autosquash 使用rebase自動(dòng)合并被標(biāo)記為fixup!的commit,其實(shí)是根據(jù)sha值來(lái)的。

命令操作

  1.繼續(xù)修復(fù)如下圖所示對(duì)應(yīng)的bug

如何使用Git rebase命令

  2、修改完之后執(zhí)行 git commit --fixup 需要合并的commit id

如何使用Git rebase命令

  3、commit fixup 之后的效果

如何使用Git rebase命令

  4、執(zhí)行g(shù)it rebase -i --autosquash 需要合并commit id的父級(jí)commit id

    或者

git rebase -i --autosquash commit id^
   

如何使用Git rebase命令

  5、執(zhí)行rebaseautosquash結(jié)果

如何使用Git rebase命令

看完這篇關(guān)于如何使用Git rebase命令的文章,如果覺(jué)得文章內(nèi)容寫(xiě)得不錯(cuò)的話,可以把它分享出去給更多人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI