我們有時候開發代碼需要把代碼同步到多個遠程庫中,如何操作才能做到呢?
我們知道,git是分佈式版本控制系統,同步到多個遠程庫時,需要用不同的名稱來標識不同的遠程庫,而git給遠程庫起的默認名稱是origin。所以我們需要修改、配置名稱,以關聯不同遠程庫。有兩種方式!
爲了方便舉例,我以GitHub和Gitee(碼雲)作爲示例!
同步方式
命令方式同步
先刪除已關聯的名爲origin的遠程庫:
複製
1 |
git remote rm origin |
然後,再關聯GitHub的遠程庫:
複製
1 |
git remote add github [email protected]:chloneda/demo.git |
接着,再關聯碼雲的遠程庫:
複製
1 |
git remote add gitee [email protected]:chloneda/demo.git |
配置方式同步
修改.git文件夾內的config文件:
複製
1 2 3 4 5 6 7 8 9 10 11 |
[core] repositoryformatversion = 0 filemode = true bare = false logallrefupdates = true [remote "origin"] url = [email protected]:chloneda/demo.git fetch = +refs/heads/*:refs/remotes/github/* [branch "master"] remote = origin merge = refs/heads/master |
將上述文件內容[remote “origin”]內容複製,修改origin名稱,內容如下:
複製
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
[core] repositoryformatversion = 0 filemode = true bare = false logallrefupdates = true [remote "github"] url = [email protected]:chloneda/demo.git fetch = +refs/heads/*:refs/remotes/github/* [remote "gitee"] url = [email protected]:chloneda/demo.git fetch = +refs/heads/*:refs/remotes/gitee/* [branch "master"] remote = origin merge = refs/heads/master |
查看遠程庫
通過以上兩種方式的任一種方式配置完成後,我們用git remote -v查看遠程庫信息:
複製
1 2 3 4 |
gitee [email protected]:chloneda/demo.git (fetch) gitee [email protected]:chloneda/demo.git (push) github [email protected]:chloneda/demo.git (fetch) github [email protected]:chloneda/demo.git (push) |
可以看到兩個遠程庫,說明配置生效了。
上傳代碼
複製
1 2 |
git add . git commit -m "update" |
提交到github
複製
1 |
git push github master |
提交到碼雲
複製
1 |
git push gitee master |
更新代碼
複製
1 2 3 4 5 |
# 從github拉取更新 git pull github # 從gitee拉取更新 git pull gitee |
踩到的坑
上述過程中,更新或提交代碼時可能會遇到fatal:refusing to merge unrelated histories (拒絕合併無關的歷史) 錯誤,解決辦法:
首先將遠程倉庫和本地倉庫關聯起來。
複製
1 |
git branch --set-upstream-to=origin/remote_branch your_branch |
其中,origin/remote_branch是你本地分支對應的遠程分支,your_branch是你當前的本地分支。
然後使用git pull整合遠程倉庫和本地倉庫。
複製
1 |
git pull --allow-unrelated-histories (忽略版本不同造成的影響) |
重新更新、提交即可。
注: 如遇到 Git沒有共同祖先的兩個分支合併 的情形請自行查詢!