为了下文讨论方便,我们将要迁移的git仓库称为本地仓库,远程git仓库称为远程仓库。要求保留提交记录,下面是迁移的步骤。
1.创建空的远程仓库
1.1.在GitLab web页面创建
创建完成后,将得到git地址:http://10.69.12.11/android/hello.git
1.2.使用GitLab或GitHub提供的API创建
为了以最简单的方式使用API,我将在~/.bashrc配置文件中编写一段shell脚本来完成:
~$ vim ~/.bashrc
在.bashrc最后添加以下这个内容:
- GitLab版本:
repo_create(){
# 判断是否存在参数,有,则赋给repo_name变量,否则使用当前目录作为repo_name的值
if [ $1 ];then
repo_name=$1
else
repo_name=`basename $(pwd)`
echo "set Repo Name to ${repo_name}"
fi
# 使用GitLab Api创建远程仓库
# oExkVZEW2WKDcoF6mXdW是Personal access tokens,在gitlab web上创建
# name=${repo_name}是指定仓库的名称
# namespace_id=12是group id可以在gitlab上查到
# http://10.69.12.11/api/v4/projects,则是GitLab服务器的地址,及api
curl -k --request POST --header "PRIVATE-TOKEN:oExkVZEW2WKDcoF6mXdW" --data "name=${repo_name}&namespace_id=12" http://10.69.12.11/api/v4/projects
}
- GitHub版本:
repo_create(){
# 判断是否存在参数,有,则赋给repo_name变量,否则使用当前目录作为repo_name的值
if [ $1 ];then
repo_name=$1
else
repo_name=`basename $(pwd)`
echo "set Repo Name to ${repo_name}"
fi
# 使用GitHub Api创建远程仓库
# 8ad7a0e3faaa7574c4c1f38b5280c7d9ecf980ab是Personal access tokens,在GitHub上创建
# '{"name":"'${repo_name}'"}'是指定仓库的名称
curl -u '[email protected]:8ad7a0e3faaa7574c4c1f38b5280c7d9ecf980ab' https://api.github.com/user/repos -d '{"name":"'${repo_name}'"}'
}
执行source命令,使用配置文件生效:
~$ source ~/.bashrc
使用repo_create创建远程仓库:
~$ repo_create Hello
成功将创建后,会返回http://10.69.12.11/android/hello.git。
GitLab API参考https://docs.gitlab.com/ce/api/
2.删除本地仓库原先关联的远程仓库
~/local_project$ git remote rm origin
3.将本地仓库关联到新的远程仓库
~/local_project$ git remote add origin http://10.69.12.11/android/hello.git
注意:如果没有进行第2点的操作,将会报如下错:
fatal: remote origin already exists.
4.将本地仓储的代码提交到待提交缓存中
~/local_project$ git add .
5.写备注(可选)
~/local_project$ git commit -m "迁移Local_project项目到远程hello仓库"
6.合并历史记录(当远程仓库创建并初始化后,即做了git init操作,就要进行这一步的操作,否则跳过)
6.1.指定要合并的分支
~/local_project$ git branch --set-upstream-to=origin/master master
注意:上面的意思是将本地master分支与远程的origin/master分支进行合并。
6.2.开始合并
~/local_project$ git pull origin master --allow-unrelated-histories
7.提交代码
将代码提交到远程仓库
扫描二维码关注公众号,回复:
10897525 查看本文章
~/local_project$ git push -u origin master
点击关注: