Git的其他参考文章:
問:用一般方式的合併,跟使用
rebase方式合併,有什麼不同?各有何優缺點?一般的合併方式,有些情況(非快轉合併)會產生一個額外的 commit 來接合兩邊分支,而 rebase 合併分支跟一般的合併分支的明顯差別,就是使用 rebase 方式合併分支不會有這個合併的 Commit。
如果就以最後的的結果來說,檔案內容來說是沒什麼差別,但在 Git 的歷史紀錄上來說就有一些差別,誰 rebase 誰,會造成歷史紀錄上先後順序不同的差別。例如
cat分支 rebase 到dog分支的話,表示cat分支會被接到dog分支的後面;反之如果是dog分支 rebase 到cat上的話,表示dog分支 會被接到cat分支的後面。使用 rebase 的好處,是整理出來的歷史紀錄不會有合併用的 commit,看起來比較乾淨(也是有些人不覺得這乾淨多少),另外歷史紀錄的順序可以依照誰 rebase 誰而決定先後關係(不過這點不一定是優點或缺點,端看整理的人而定);缺點就是它相對的比一般的合併來得沒那麼直覺,一個不小心可能會弄壞掉而且還不知道怎麼 reset 回來,或是發生衝突的時候就會停在一半,對不熟悉 rebase 的人來說也許是個困擾。
通常在還沒有推出去但感覺得有點亂(或太瑣碎)的 commit,我會先使用 rebase 來整理分支後再推出去。rebase 等於是在修改歷史,這個行為會做出平行時空,修改已經推出去的歷史可能會對其它人帶來困擾,所以對於已經推出去的內容,請不要任意使用 rebase。
【狀況題】怎麼有時候推不上去…
偶爾在執行 Push 指令的時候會出現這個錯誤訊息:
1 | $ git push |
這段訊息的意思是線上版本的內容比你電腦裡這份還要新,所以 Git 不讓你推上去。
怎麼造成的?
通常這個狀況會發生在多人一起開發的時候,想像一下這個情境:

- Sherly 跟 Eddie 兩個人在差不多的時間都從 Git Server 上拉了一份資料下來準備進行開發。
- Sherly 手腳比較快,先完成了,於是先把做好的成果推一份上去。
- Eddie 不久後也完成了,但當他要推上去的時候發現推不上去了…
怎麼解決?
解決方法算是有兩招
第一招:先拉再推
因為你電腦裡的內容是比較舊的,所以你應該先拉一份線上版本的回來更新,然後再推一次:
1 | $ git pull --rebase |
這裡加了 --rebase 參數是表示「內容抓下來之後請使用 Rebase 方式合併」,當然你想用一般的合併方式也沒問題。合併如果沒發生衝突,接著應該就可以順利往上推了。
第二招:無視規則,總之就是聽我的!(誤)
凡事總有先來後到,在上面的例子中,Sherly 先推上去的內容,後推的人就是應該拉一份下來更新,不然照規定是推不上去的。不過這規則也是有例外,只要加上了 --force 或是 -f 參數,它就會強迫硬推上去,把 Sherly 之前的內容蓋掉:
1 | $ git push -f |
雖然這樣一定會成功,但接下來你就要去面對 Sherly,跟她解釋為什麼你把她的進度蓋掉了。更多關於 Force Push 的說明,可參考「【狀況題】聽說 git push -f 這個指令很可怕,什麼情況可以用它呢?」章節介紹。