将 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 协作新篇章!

相关推荐
wangruofeng1 小时前
为什么 build-your-own-x 能成为 GitHub Star 排名第一
github·ai编程
白鲸开源5 小时前
杀疯了!SeaTunnel AI CLI 解锁数据集成新玩法
大数据·人工智能·github
Skylwn6 小时前
保姆级教程之将 GitHub Models 接入 NewAPI
笔记·github
Better Bench7 小时前
Claude Code 学习指南:优秀 GitHub 仓库推荐与进阶路线图
github·claude code·学习指南
逛逛GitHub8 小时前
强烈推荐看看这个演讲,还配套 7 万 Star 的开源 Skill。
github
墨神谕8 小时前
第一次上传本地项目至GitHub
github
合合技术团队9 小时前
海外发票智能解析:跨版式、多税制票据的自动化处理方案(附GitHub项目地址)
运维·自动化·github·ocr
Hommy8810 小时前
【开源剪映小助手】图片信息生成接口
开源·github·视频剪辑自动化·剪映api
甄心爱学习10 小时前
【项目实训】法律文书智能摘要系统5
python·github
前端点线面12 小时前
GitHub 5月热点:Claude Code生态大爆发
github