git使用之(五)合并两个不相关的Git仓库

本文详述了如何将SVN仓库的内容合入Git仓库,同时保留提交历史的方法。通过将SVN仓库转换为Git仓库并将其作为分支合并到目标Git仓库中,实现了两个仓库的融合。

大致是这样的场景:有两个仓库,一个Git仓库,一个SVN仓库,都是非空的。现在要把SVN仓库中的内容合入Git仓库中,并保留提交记录。听起来有点奇怪,不过现实中的问题总是千奇百怪加变态。既然遇到了,总得想办法解决。花了将近1个小时,简单总结一下。

按照问题的描述,问题可以演变成两部分:

  1. 将SVN仓库转换成Git仓库,这一步很简单。百度说:上我吧,我能给你100页的答案;谷歌说:上我吧,我能给你1000页的答案(Sounds weird)。简单来说,就是使用git svn clone 命令,或者使用TortoiseGit或其他工具即可解决,不做赘述,各位看官还是上百度或者谷歌吧;
  2. 合并两个Git仓库。
    简单起见,笔者以test1、test2为例,讲解演示将test2仓库合并到test1中。

思路

要想将test2合入test1中,那么可以将test2伪造成test1仓库的一个分支,然后合并到test1仓库中(的指定分支,本文为master)

Action

1. clone两个仓库,放入同一个目录中,例如:
workspace
|-test1
|-test2
2. 将test2移入test1目录中,此时目录结构变为如下:
workspace
|-test1
|-test2
3. 将目录切换至test1

cd test1

4. 执行以下命令,将test2作为远程仓库,添加到test1中,并设置别名为test2

git remote add test2 ./test2

5. 执行以下命令,从test2仓库下载数据到本地

git fetch test2

6. 将test2仓库下载过来的master分支作为新分支checkout到本地,并将新分支设为test2

git checkout -b test2 test2/master

7. 切换回test1仓库的master分支

git checkout master

8. 将test2仓库的master分支合入test1仓库的master分支。如不添加allow-unrelated-histories 参数,可能会报fatal: refusing to merge unrelated histories 的异常。

git merge test2 --allow-unrelated-histories

9. push到test1仓库

git push
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老周聊架构

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值