gitlab仓库迁移至bitbucket

0. 场景描述

假设已有一个gitlab仓库:ssh://xxx_origin.git,想要把这个仓库迁移至bitbucket上。

默认gitlab和bitbucket的SSH key都已添加。

1. 新建bitbucket仓库

在bitbucket上创建新的仓库,并复制url地址。假设为:

bash 复制代码
https://xxx/NewOrigin.git 或者 [email protected]:NewOrigin.git

2. 克隆gitlab原有仓库

bash 复制代码
git clone ssh://xxx_origin.git

# 保证本地有旧有仓库的所有分支,最后git push origin --all的时候才会把所有分支迁移过去
git checkout branch_name

# 保证本地有旧有仓库的所有tag,最后git push origin --tags的时候才会把所有tag迁移过去
git checkout tag_name

# 显示本地所有的远程仓库地址
git remote -v
# 注意:若有关联,先删除本地代码分支与旧Gitlab分支的关联关系
# 没有就不需要执行
# git remote remove origin

# 把旧远端仓库改个名字,当前的一般默认origin,
# 注意:想回到旧仓库就要切换回去 git remote rm origin; git remote rename old-origin origin
git remote rename origin old-origin

# 旧仓库与新的仓库关联起来, https://xxx/NewOrigin.git 为新仓库地址
git remote add origin https://xxx/NewOrigin.git 

# 将本地的所有分支都推送到新仓库的远程分支
# 此步骤若报错,详见下面报错详情
git push origin --all 
# 将本地的所有tags都推送到新仓库的远程分支
git push origin --tags

2. 报错

  1. git push origin --all 报错如下:

解决方法:

切换到报错的分支:

bash 复制代码
git checkout master
git pull origin master --allow-unrelated-histories
git push
  1. 新仓库没有master分支的内容
    解决方法:
    在旧仓库上重新push
bash 复制代码
git push -u origin

参考链接

https://zhuanlan.zhihu.com/p/617563961

相关推荐
Caroline皮皮3 小时前
团队开发中的Git 文件名大小写不敏感导致的文件冲突
git
9ilk4 小时前
【Git】--- 多人协作实战场景
git
lllsure6 小时前
Git使用与管理
git
座山雕~7 小时前
Maven超级详细安装部署
git·github·maven
GanGuaGua9 小时前
linux系统下如何提交git和调试
服务器·git
csj5016 小时前
git分支合并信息查看
git
gqkmiss16 小时前
Git Cherry-pick:核心命令、实践详解
前端·git·前端框架·commit·cherry-pick
小生不才yz21 小时前
15. git push
git
阿虎儿21 小时前
基于三方开源项目二次开发的版本管理最佳实践
git
曼陀罗1 天前
【Git篇】commit失败后,展示: stash@{0}WIP on Feature_xx:
git