git同步代碼至github和gitee(碼雲)

我們有時候開發代碼需要把代碼同步到多個遠程庫中,如何操作才能做到呢?

我們知道,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沒有共同祖先的兩個分支合併 的情形請自行查詢!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章