目錄
1.遇到的問題
關聯遠程倉庫,操做順序以下:
2.解決方法
3.git merge 與 git rebase
4.git pull 與 git pull --rebase
5.更多參考
博客逐步遷移至 極客兔兔的小站html
本地有一個git倉庫,在github上新建了一個空的倉庫,可是更新了REWADME.md的信息,即在github上多了一個提交。git
關聯遠程倉庫,操做順序以下:
- git remote add origin ****.git
- git push -u origin master 報錯,須要先pull
- git pull origin master 報錯 error: failed to push some refs to
- 第三步改成 git pull
--rebase
origin master
- git merge 和 git rebase 都是將遠程分支與本地分支合併的一種方法,git merge 會生成一個新的節點,例如A和B都位於同一個HEAD,A提交了2個commit C1和C2,B 提交了2個commit C3和C4,git merge的結果是在C3和C4以後合併生成C5,這樣提交歷史比較清晰,但多了一個C5
- 假設A已經將C1和C2 push到了遠程分支,那麼B 使用git rebase則會將C3和C4緩存到.git/rebase中,恢復到以前的狀態,更新C1和C2,而後再將C3和C4做爲補丁應用到C2的狀態上。結果以下:
原始狀態->C1->C2->C3'->C4',C3'和C4'爲git 根據C3和C4生成的補丁,log是一條直線,並且沒有多餘的C5,可是平行信息丟失。
- git pull = git fetch + git merge
- git pull --rebase = git fetch + git rebase
關於merge 與 rebase 的區別與優劣能夠參考stackoverflow上的回答
更多關於git 遠程操做能夠參考Git遠程操做詳解github