婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Git rebase命令使用實戰

Git rebase命令使用實戰

熱門標簽:華創e路航彩票銷售點地圖標注 鶴壁外呼系統公司 suitecrm 地圖標注 高德地圖標注常顯 揭陽電腦外呼系統公司 外呼系統號顯示星號怎么看 銀川語音外呼系統中心 承德地圖標注公司收費 臨沂ai電銷機器人招商

一、前言

  一句話,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 需要合并commit id的父級commit id

    或者

git rebase -i --autosquash commit id^
   

  5、執行rebaseautosquash結果

到此這篇關于Git rebase命令使用實戰的文章就介紹到這了,更多相關Git rebase命令內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 一不小心git rebase后出現(master|REBASE 1/10)的問題及解決辦法
  • 解決使用commit提交大文件無法推送到遠程庫問題及git rebase使用詳解
  • git rebase 成功之后撤銷的操作方法

標簽:許昌 三沙 咸寧 汕尾 棗莊 萊蕪 忻州 七臺河

巨人網絡通訊聲明:本文標題《Git rebase命令使用實戰》,本文關鍵詞  Git,rebase,命令,使用,實戰,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Git rebase命令使用實戰》相關的同類信息!
  • 本頁收集關于Git rebase命令使用實戰的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 敖汉旗| 蓬溪县| 全南县| 永城市| 洪泽县| 姚安县| 沧源| 曲松县| 乌兰县| 寻甸| 离岛区| 琼海市| 新巴尔虎右旗| 平南县| 封丘县| 河北区| 桐乡市| 醴陵市| 瓮安县| 怀柔区| 南靖县| 开化县| 尉氏县| 丽江市| 内乡县| 临泉县| 故城县| 武邑县| 洛隆县| 黄石市| 汤原县| 醴陵市| 香格里拉县| 凤庆县| 永康市| 封开县| 广东省| 称多县| 霍林郭勒市| 巴中市| 台山市|