假设私有服务器ip为1.2.3.4
原地址为:git@github.com:[gitUserName]/[gitCodePath].git
新地址为:git@1.2.3.4:/home/git/codes/localName.git
一共涉及:Client机器、git私有服务器、git原地址
1. 迁移
- 登录Client机器,clone一份裸版本库:
git clone --bare git@github.com:[gitUserName]/[gitCodePath].git localName.git
- 登录git私有服务器,初始化仓库
cd /home/git/codes && git init --bare localName.git
- 将Client机器的公钥加入git私有服务的
~/.ssh/authorized_keys
- 在Client提交镜像到git私有服务器
cd …/localName.git && git push --mirror git@1.2.3.4:/home/git/codes/localName.git
以上,代码迁移完毕,以下为使用流程
2. 使用
以下均在Client机器操作:
-
将迁移中第一步clone -bare得到的裸版本库rm掉,这个已经没用了;
-
从git私有服务器clone代码下来
git clone git@1.2.3.4:/home/git/codes/localName.git
可以正常提交代码,并能看到完整的git log和git blame
3. 问题
- 部分仓库迁移完成后,client机器执行clone时会报错“warning: 远程 HEAD 指向一个不存在的引用,无法检出。”
执行:git clone git@1.2.3.4:/home/git/codes/localName.git
报错:warning: 远程 HEAD 指向一个不存在的引用,无法检出。
这部分应该是受到了git将默认主branch从master改为main的影响,导致找不到branch,执行git br得到的结果是空的,解决:
1.1 git br -a可以看到remotes/origin/main
1.2 git ch remotes/origin/main
1.3 git ch -b remotes/origin/main
1.4 git br -m remotes/origin/main master(需要了执行)
这样,就创建了remotes/origin/main并可选的rename为master,同时保留remotes/origin/main中的代码
- git仓库迁移之前,假设Client机器已有在编码中的代码,这部分代码不想重新从私有仓库clone,那么修改其remote_url,方法:
方法1:使用git remote set-url命令,怎么用网上查吧,我用的第二种方法;
方法2:修改.git/config文件中的url内容(从git私有服务器执行一遍git clone、然后把拿到的.git/config中url copy过来就行)
参考:
https://www.cnblogs.com/zhangruoxu/p/6706530.html
https://www.liaoxuefeng.com/wiki/896043488029600/899998870925664