将 Gitee 混合项目仓库拆分并精准迁移至 GitHub(保留完整 Commit 历史)

实战:将 Gitee 混合项目仓库拆分并精准迁移至 GitHub(保留完整 Commit 历史)

  • [将 Gitee 混合项目仓库拆分并精准迁移至 GitHub](#将 Gitee 混合项目仓库拆分并精准迁移至 GitHub)
    • [🚀 背景介绍](#🚀 背景介绍)
    • [🛠️ 迁移三步走](#🛠️ 迁移三步走)
      • 第一步:准备本地工作区
      • [第二步:利用 git subtree 拆分历史](#第二步:利用 git subtree 拆分历史)
      • [第三步:精准推送到 GitHub](#第三步:精准推送到 GitHub)
    • [🔐 避坑指南:GitHub 身份验证与安全防护](#🔐 避坑指南:GitHub 身份验证与安全防护)
    • [💡 后续开发建议](#💡 后续开发建议)

将 Gitee 混合项目仓库拆分并精准迁移至 GitHub

🚀 背景介绍

在开发初期,我们常为了方便将多个小项目放在同一个 Gitee 仓库的不同子文件夹中。但随着项目成熟,我们需要将它们拆分出来,迁移到 GitHub 建立独立的仓库。

挑战点:

  1. 历史记录不能丢:必须保留每个项目的每一次提交记录。
  2. 路径归位:迁移后,子文件夹的内容要变成新仓库的根目录。
  3. 安全防护:GitHub 的 Secret 扫描机制会拦截包含敏感信息(如 AccessKey)的代码推送。

🛠️ 迁移三步走

假设原 Gitee 仓库为 project.git,内含 java_gobanglottery-system 两个子文件夹。

第一步:准备本地工作区

克隆原仓库并进入临时目录:

powershell 复制代码
git clone https://gitee.com/sweet-ren/project.git migration_tmp
cd migration_tmp

第二步:利用 git subtree 拆分历史

git subtree 是 Git 的高级命令,能够从主仓库中提取某个特定目录的提交历史,并生成一个全新的本地分支。

powershell 复制代码
# 1. 提取 java_gobang 的历史到 split_gobang 分支
git subtree split --prefix=java_gobang -b split_gobang

# 2. 提取 lottery-system 的历史到 split_lottery 分支
git subtree split --prefix=lottery-system -b split_lottery

第三步:精准推送到 GitHub

由于 GitHub 默认分支已改为 main,我们使用冒号语法进行推送:

powershell 复制代码
# 推送五子棋项目
git push https://github.com/您的用户名/java_gobang.git split_gobang:main

# 推送抽奖系统项目
git push https://github.com/您的用户名/lottery-system.git split_lottery:main

🔐 避坑指南:GitHub 身份验证与安全防护

  1. 身份认证 (Token)
    GitHub 目前强制要求使用 Personal Access Token (PAT) 替代密码。
    入口:Settings > Developer settings > Tokens (classic)。
    权限:必须勾选 repo。
    使用:推送时在密码框输入生成的 ghp_... 字符串。
  2. 拦截处理 (Push Protection)
    如果您代码中包含了云服务的 AccessKey,GitHub 会抛出 GH013: Repository rule violations 错误。
    原因:GitHub 检测到敏感信息泄露。
    解决:GitHub 会在报错信息中提供一个 Unblock Secret URL。点击该链接并在网页中确认允许推送(建议仅对测试用 Key 这样做),然后重新执行推送命令即可。

💡 后续开发建议

迁移完成后,建议采用以下方式管理敏感信息,避免再次被拦截:

.gitignore:将包含 Key 的配置文件加入忽略列表。

环境变量:在代码中使用 ${MY_KEY} 占位符,通过系统环境变量注入真实值。

模板文件:提供 application.properties.example 供他人参考。


🎯 总结

通过 git subtree split 命令,我们实现了:

子文件夹层级自动归位(不再有多余的父目录)。

100% 保留了每一条 Commit 记录。

成功绕过 GitHub 安全拦截。

迁移成功,开启 GitHub 协作新篇章!

相关推荐
第一程序员1 天前
数据工程 pipelines 实践
python·github
CV工程师(Ctrl)1 天前
OpenClaw 安装与飞书接入(2026-04-19)
node.js·github·飞书·火山引擎·openclaw
历程里程碑1 天前
2. Git版本回退全攻略:轻松掌握代码时光机
大数据·c++·git·elasticsearch·搜索引擎·github·全文检索
darkb1rd1 天前
lingbot-map:流式 3D 重建实战指南与解析
开源·github·好物分享
AC赳赳老秦1 天前
HR必备:OpenClaw批量筛选简历、发送面试通知,优化招聘流程
运维·人工智能·python·eclipse·github·deepseek·openclaw
yyuuuzz1 天前
独立站搭建:从入门到避坑实战
前端·git·github
splage1 天前
Nginx 反向代理之upstream模块以及完整配置反向代理示例
git·nginx·github
jiayong231 天前
GitHub 二开并持续同步上游稳定分支详细指南
github
逛逛GitHub1 天前
暴击设计行业的 Claude Design ,系统提示词在 GitHub 上泄露了。
github
程序猿阿伟1 天前
《QClaw隐藏的GitHub自动化神级用法》
运维·自动化·github