Git rebase命令實戰

1、前言

  一句話,git rebase 能夠幫助項目中的提交歷史乾淨整潔!!!git

2、避免合併出現分叉現象

git merge操做

  一、新建一個 develop 分支shell

  

   二、在develop分支上新建兩個文件app

  

  三、而後分別執行 add、commit、push工具

  

   四、接着切換到master分支spa

   分別添加c.txt 和 d.txt兩個文件,分別進行add、commit、push3d

  

  五、如今想把develop分支上開發的部分合併到master分支上日誌

  

  六、git merge 會將master和develop合併的過程經過以下形式展現出來。blog

   藉助 gitk 命令索引

  

  藉助sourceTree工具開發

  

git rebase操做

  若是master和develop分支上的這些開發部分都是同一我的操做,在合併的時候不想產生這種分叉的結果,怎麼辦呢?

  git-rebase命令簡介:用在從上游分支獲取最新commit信息,並有機的將當前分支和上游分支進行合併。由於develop分支是在master分支基礎上創建的,因此master稱爲topic的上游分支。

  一、首先經過 git reset 恢復到master合併以前的狀態

  二、切換到develop分支,執行以下操做

  

  

   三、若是你想把 rebase 以後的 master 分支推送到遠程倉庫,Git 會阻止你這麼作,由於兩個分支包含衝突。但你能夠傳入 –force 標記來強行推送。

  

  四、查看一下develop分支合併的效果,以下。

  

  

  看一下rebase的結果,就像是develop先把本身的提交保存起來,而後將master中的提交合並過來,最後在加上自身分支的提交,這樣就不存在分支的合併效果了。

  五、接着切換到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命令執行

  一、git rebase -i HEAD~3

     二、編輯合併信息

  

    三、修改commit信息

  

   四、commit信息預覽

  

   五、commit合併結果

  

   六、能夠看到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

  

   二、修改完以後執行 git commit --fixup 須要合併的commit id

  

  三、commit fixup 以後的效果

  

   四、執行git rebase -i --autosquash 須要合併commit id的父級commit id

    或者

    git rebase -i --autosquash commit id^

  

  五、執行rebase autosquash結果

  

相關文章
相關標籤/搜索