合并两个git仓库

昨天把博客更新了, 是在新仓库进行的, 但是原博客是在一个仓库, 希望保留历史记录又不想分两个仓库管理, 于是百度了一下找到这篇文章, 特地转过来保存也方便自己或者有人以后需要用到的时候, 以下是原文内容:

为了让大家看的明白,我重新描述下case如下:

  1. 有2个git仓库:repo1、repo2;
  2. 想将repo1中的文件移入repo2;
  3. repo1的历史日志要保留;

首先,快速创建2个仓库。

1
2
3
4
5
6
7
8
9
10
11
12
13
mkdir repo1
cd repo1
git init
echo "repo1.txt" > repo1.txt
git add repo1.txt
git ci -m "init repo1"

mkdir repo2
cd repo2
git init
echo "repo2.txt" > repo2.txt
git add repo2.txt
git ci -m "init repo2"

结果目录路径是:

1
2
3
4
5
6
7
repo1/
repo1/repo1.txt
repo1/.git

repo2/
repo2/repo2.txt
repo2/.git

再次注意,想要的效果是:

1
2
3
4
repo2/
repo2/repo1.txt
repo2/repo2.txt
repo2/.git

然后,需要五步命令:

1、将repo1作为远程仓库,添加到repo2中,设置别名为other

1
[jot@myhost repo2]$ git remote add other ../repo1/

2、从repo1仓库中抓取数据到本仓库

1
2
3
4
5
6
7
8
[jot@myhost repo2]$ git fetch other
warning: no common commits
remote: Counting objects: 3, done.
remote: Total 3 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (3/3), done.
From ../repo1

* [new branch] master -> other/master

3、将repo1仓库抓去的master分支作为新分支checkout到本地,新分支名设定为repo1

1
2
3
[jot@myhost repo2]$ git checkout -b repo1 other/master
Branch repo1 set up to track remote branch master from other.
Switched to a new branch 'repo1'

4、切换回repo2的master分支

1
2
[jot@myhost repo2]$ git checkout master
Switched to branch 'master'

5、将repo1合并入master分支

1
2
3
4
5
[jot@myhost repo2]$ git merge repo1
Merge made by recursive.
repo1.txt | 1 +
1 files changed, 1 insertions(+), 0 deletions(-)
create mode 100644 repo1.txt

已经完成,可以push到服务器了。

可能遇到的问题:

1
2
3
4
5
1. 在合并时有可能两个分支对同一个文件都做了修改,这时需要解决冲突,对文本文件来说很简单,根据需要对冲突的位置进行处理就可以。对于二进制文件,需要用到如下命令。
git checkout --theirs YOUR_BINARY_FILES // 保留需要合并进来的分支的修改
// git checkout --ours YOUR_BINARY_FILES // 保留自己的修改
git add YOUR_BINARY_FILES
git comm

总结:

  1. 大致思路是伪造远程的repo1仓库为repo2的一个分支,然后合并进来;
  2. 若是文件有冲突、或要建立子目录,建议在repo1中先解决,再进行如上操作。

原文: 合并两个git仓库