博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
合并两个不相关的Git仓库
阅读量:6616 次
发布时间:2019-06-25

本文共 1163 字,大约阅读时间需要 3 分钟。

  hot3.png

大致是这样的场景:有两个仓库,一个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

参考文档

  1. 《合并两个git仓库》:
  2. 《如何用 Git 合并两个库,并保留提交历史》:

版权说明

本文采用 CC BY 3.0 CN协议 进行许可。 可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。

关注我

博客:

微信公众号:

转载于:https://my.oschina.net/eacdy/blog/1513698

你可能感兴趣的文章
尚学linux课程---3、linux网络说明
查看>>
Git 跟 GitHub 是什么关系?
查看>>
String.split()方法
查看>>
IE6下jQuery选中select的BUG
查看>>
Tensorflow在win10下的安装(CPU版本)
查看>>
嵌入式平台做深度学习算法,不可不重视的4件事
查看>>
一次优化记录
查看>>
如何调用一个数据完整的firefox浏览器
查看>>
cgroup代码浅析(2)
查看>>
会计的思考(42):会计如何转变为公司的内部财务顾问
查看>>
利用钥匙串,在应用里保存用户密码的方法
查看>>
final,finally和finalize之间的区别
查看>>
python 装饰器
查看>>
[辟谣]下蹲猛起来眼前发黑是心脏衰竭的表现?别扯了!
查看>>
paper 96:计算机视觉-机器学习近年部分综述
查看>>
vuex状态管理详细使用方法
查看>>
不要等有了足够的钱才选择去创业!!!
查看>>
手把手教你画嘴巴,以后再也不怕画嘴巴了
查看>>
selenium - webdriver - 截图方法get_screenshot_as_file()
查看>>
linux 命令 — archive
查看>>