git rebase 和 git merge 有啥區(qū)別?

git merge:將兩個(gè)分支谆甜,合并提交為一個(gè)新提交垃僚,并且新提交有2個(gè)parent。

git rebase:會(huì)取消分支中的每個(gè)提交规辱,并把他們臨時(shí)存放谆棺,然后把當(dāng)前分支更新到最新的origin分支,最后再把所有提交應(yīng)用到分支上罕袋。

什么是 rebase?

git rebase可以把它理解成是“重新設(shè)置基線”改淑,將當(dāng)前分支重新設(shè)置開始點(diǎn)。這個(gè)時(shí)候才能知道當(dāng)前分支與你需要比較的分支之間的差異炫贤。

原理:rebase需要基于一個(gè)分支來(lái)設(shè)置當(dāng)前分支的基線溅固,這基線就是當(dāng)前分支的開始時(shí)間軸向后移動(dòng)到最新跟蹤分支的最后面,這樣你的當(dāng)前分支就是最新跟蹤分支兰珍。這里的操作是基于文件事務(wù)處理的侍郭,所以不用怕中間失敗會(huì)影響文件的一致性。在中間的過(guò)程中可以隨時(shí)取消rebase 事務(wù)掠河。

git rebase 和 git merge 有啥區(qū)別亮元?

rebase會(huì)把當(dāng)前分支的 commit 放到公共分支的最后面,所以叫變基。就好像從公共分支又重新拉出來(lái)這個(gè)分支一樣唠摹。

舉例:如果從 master 拉個(gè)feature分支出來(lái),然后提交了幾個(gè) commit,這個(gè)時(shí)候剛好有人把他開發(fā)的東西合并到 master 了,這個(gè)時(shí)候 master 就比你拉分支的時(shí)候多了幾個(gè) commit,如果這個(gè)時(shí)候你 rebase master 的話爆捞,就會(huì)把你當(dāng)前的幾個(gè) commit,放到那個(gè)人 commit 的后面勾拉。

merge會(huì)把公共分支和你當(dāng)前的commit 合并在一起煮甥,形成一個(gè)新的 commit 提交

注意:

不要在公共分支使用rebase

本地和遠(yuǎn)端對(duì)應(yīng)同一條分支,優(yōu)先使用rebase,而不是merge

拋出問題:

為什么不要再公共分支使用rebase?

因?yàn)橥蠓诺倪@些 commit 都是新的,這樣其他從這個(gè)公共分支拉出去的人,都需要再 rebase,相當(dāng)于你 rebase 東西進(jìn)來(lái)藕赞,就都是新的 commit 了

舉例:

1-2-3 是現(xiàn)在的分支狀態(tài)

這個(gè)時(shí)候從原來(lái)的master ,checkout出來(lái)一個(gè)prod分支

然后master提交了4.5成肘,prod提交了6.7

這個(gè)時(shí)候master分支狀態(tài)就是1-2-3-4-5,prod狀態(tài)變成1-2-3-6-7

如果在prod上用rebase master ,prod分支狀態(tài)就成了1-2-3-4-5-6-7

如果是merge

1-2-3-6-7-8

........ |4-5|

會(huì)出來(lái)一個(gè)8斧蜕,這個(gè)8的提交就是把4-5合進(jìn)來(lái)的提交

常用指令

git rebase -I dev 可以將dev分支合并到當(dāng)前分支

這里的”-i“是指交互模式双霍。就是說(shuō)你可以干預(yù)rebase這個(gè)事務(wù)的過(guò)程,包括設(shè)置commit message批销,暫停commit等等洒闸。

git rebase –abort 放棄一次合并

合并多次commit操作:

1 git rebase -i dev

2 修改最后幾次commit記錄中的pick 為squash

3 保存退出,彈出修改文件,修改commit記錄再次保存退出(刪除多余的change-id 只保留一個(gè))

4 git add .

5 git rebase --continue

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市均芽,隨后出現(xiàn)的幾起案子丘逸,更是在濱河造成了極大的恐慌,老刑警劉巖掀宋,帶你破解...
    沈念sama閱讀 218,451評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件深纲,死亡現(xiàn)場(chǎng)離奇詭異羞反,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)囤萤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)是趴,“玉大人涛舍,你說(shuō)我怎么就攤上這事∷敉荆” “怎么了富雅?”我有些...
    開封第一講書人閱讀 164,782評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)肛搬。 經(jīng)常有香客問我没佑,道長(zhǎng),這世上最難降的妖魔是什么温赔? 我笑而不...
    開封第一講書人閱讀 58,709評(píng)論 1 294
  • 正文 為了忘掉前任蛤奢,我火速辦了婚禮,結(jié)果婚禮上陶贼,老公的妹妹穿的比我還像新娘啤贩。我一直安慰自己,他們只是感情好拜秧,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評(píng)論 6 392
  • 文/花漫 我一把揭開白布痹屹。 她就那樣靜靜地躺著,像睡著了一般枉氮。 火紅的嫁衣襯著肌膚如雪志衍。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,578評(píng)論 1 305
  • 那天聊替,我揣著相機(jī)與錄音楼肪,去河邊找鬼。 笑死佃牛,一個(gè)胖子當(dāng)著我的面吹牛淹辞,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播俘侠,決...
    沈念sama閱讀 40,320評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼象缀,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了爷速?” 一聲冷哼從身側(cè)響起央星,我...
    開封第一講書人閱讀 39,241評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎惫东,沒想到半個(gè)月后莉给,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體毙石,經(jīng)...
    沈念sama閱讀 45,686評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評(píng)論 3 336
  • 正文 我和宋清朗相戀三年颓遏,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了徐矩。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,992評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡叁幢,死狀恐怖滤灯,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情曼玩,我是刑警寧澤鳞骤,帶...
    沈念sama閱讀 35,715評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站黍判,受9級(jí)特大地震影響豫尽,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜顷帖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評(píng)論 3 330
  • 文/蒙蒙 一美旧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧贬墩,春花似錦陈症、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至吊说,卻和暖如春论咏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背颁井。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工厅贪, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人雅宾。 一個(gè)月前我還...
    沈念sama閱讀 48,173評(píng)論 3 370
  • 正文 我出身青樓养涮,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親眉抬。 傳聞我的和親對(duì)象是個(gè)殘疾皇子贯吓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評(píng)論 2 355

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