大致是这样的场景:有两个仓库,一个Git仓库,一个SVN仓库,都是非空的。现在要把SVN仓库中的内容合入Git仓库中,并保留提交记录。听起来有点奇怪,不过现实中的问题总是千奇百怪加变态。既然遇到了,总得想办法解决。花了将近1个小时,简单总结一下。
按照问题的描述,问题可以演变成两部分:
- 将SVN仓库转换成Git仓库,这一步很简单。百度说:上我吧,我能给你100页的答案;谷歌说:上我吧,我能给你1000页的答案(Sounds weird)。简单来说,就是使用
git svn clone
命令,或者使用TortoiseGit或其他工具即可解决,不做赘述,各位看官还是上百度或者谷歌吧; - 合并两个Git仓库。
简单起见,笔者以test1、test2为例,讲解演示将test2仓库合并到test1中。
思路
要想将test2合入test1中,那么可以将test2伪造成test1仓库的一个分支,然后合并到test1仓库中(的指定分支,本文为master)
Action
-
clone两个仓库,放入同一个目录中,例如:
workspace|-test1|-test2
-
将test2移入test1目录中,此时目录结构变为如下:
workspace|-test1 |-test2
-
将目录切换至test1
cd test1
-
执行以下命令,将test2作为远程仓库,添加到test1中,并设置别名为test2
git remote add test2 ./test2
-
执行以下命令,从test2仓库下载数据到本地
git fetch test2
-
将test2仓库下载过来的master分支作为新分支checkout到本地,并将新分支设为test2
git checkout -b test2 test2/master
-
切换回test1仓库的master分支
git checkout master
-
将test2仓库的master分支合入test1仓库的master分支。如不添加
allow-unrelated-histories
参数,可能会报fatal: refusing to merge unrelated histories
的异常。git merge test2 --allow-unrelated-histories
-
push到test1仓库
git push
参考文档
- 《合并两个git仓库》:
- 《如何用 Git 合并两个库,并保留提交历史》:
版权说明
本文采用 CC BY 3.0 CN协议 进行许可。 可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
关注我
博客:
微信公众号: