Skip to main content

关于 GitHub 产品之间的迁移

了解 GitHub Enterprise Importer 可以在 GitHub 产品之间迁移的数据。

关于 GitHub 产品之间的迁移

使用 GitHub Enterprise Importer,你可以从 GitHub Enterprise Server 迁移数据到 GitHub Enterprise Cloud,或者在 GitHub Enterprise Cloud 上的帐户之间迁移数据。 有关详细信息,请参阅“关于 GitHub Enterprise Importer”。

如果迁移源为 GitHub.com 上的另一个帐户,则可以在组织之间迁移单个存储库,或在企业之间迁移整个组织。 如果迁移源为 GitHub Enterprise Server,则可以迁移存储库。

GitHub Enterprise Importer 可以迁移的数据取决于迁移源以及是迁移存储库还是组织。

从 GitHub Enterprise Server 迁移的数据

要从 GitHub Enterprise Server (GHES) 迁移,必须有 GHES 3.4.1 或更高版本。 迁移的数据取决于所使用的版本。

GHES 3.4.1+GHES 3.5.0+
Git 源(包括提交历史记录)
拉取请求
问题
里程碑
Wiki
存储库级别的项目(经典)
GitHub Actions 工作流程
提交注释
活动 Webhook
分支保护
GitHub Pages 设置
上述数据的用户历史记录
附件(请参阅“附加文件”)
发行版本

根据 GHES 版本,每个存储库适用不同的大小限制。

限制GHES <3.8.0GHES 3.8.0+
Git 源2GB10GB
Metadata2GB10GB

目前,以下数据未迁移。

  • 任何 Projects(新项目体验)
  • Code scanning 结果
  • 提交状态检查
  • Dependabot 警报
  • Dependabot 机密
  • 存储库级别的讨论
  • 编辑议题注释和拉取请求注释的历史记录
  • 存储库之间的分支关系(请参阅“关于分叉”)
  • GitHub Actions 机密、变量、环境、自托管运行器、大型运行器 或工作流运行历史记录
  • GitHub Codespaces 机密
  • GitHub 应用和 GitHub 应用安装
  • Git LFS 对象和大型二进制文件(仍然支持使用 Git LFS 的存储库,请参阅“GitHub Enterprise Importer 的限制”)
  • GitHub Packages 中的包
  • 组织级别的项目(经典)
  • 不同存储库中拉取请求与问题之间的引用(请参阅“自动链接引用和 URL”)
  • secret scanning 结果的修正状态
  • 用户帐户拥有的存储库
  • 存储库属性(公共 beta 版)
  • 存储库星级
  • 存储库观察程序
  • 规则集
  • 标记保护规则
  • 用户配置文件、SSH 密钥、签名密钥或personal access tokens
  • Webhook 密码
  • Teams
  • 用户或团队对存储库的访问权限
  • 拉取请求的存储库设置

分支保护

分支保护将一组指定的规则应用于特定分支名称或分支名称模式。 有关详细信息,请参阅“关于受保护分支”。

始终都会迁移分支保护,但不会迁移某些规则。 以下分支保护规则不会迁移。

  • 允许特定参与者绕过所需的拉取请求
  • 需要审批最近的推送
  • 在合并前要求部署成功
  • 锁定分支
  • 限制创建匹配分支的推送
  • 允许强制推送

还存在下列限制:

  • 如果分支保护规则可以选择性地用于指定不受该规则限制的人员、团队或应用(例如“限制可以关闭拉取请求评审的人员”),则不会迁移这些例外情况。
  • 如果在“指定可以进行强制推送的人员”模式下启用了“允许强制推送”规则,则不会迁移该规则。

从 GitHub.com

上其他帐户迁移的数据

如果迁移源为 GitHub.com 上的另一个帐户,则可以在组织之间迁移单个存储库,或在企业之间迁移整个组织。

组织的迁移数据

迁移组织时,目标企业帐户中会创建一个新组织。 然后,以下数据将迁移到新组织。

  • Teams
  • 存储库
  • 团队对存储库的访问权限
  • 成员特权
  • 组织级别的 Webhook(必须在迁移后重新启用,请参阅“启用 Webhook”)
  • 在组织中创建的新存储库的默认分支名称

所有存储库都以专用可见性进行迁移。 如果要将存储库的可见性设置为公共或内部,可以在迁移后使用 UI 或 API 进行设置。

团队成员身份不会迁移。 迁移后,需要将成员添加到已迁移的团队。 有关详细信息,请参阅“在 GitHub 产品之间迁移的概述”。

注意:对团队的引用(例如 @octo-org/octo-team)不会在组织迁移的过程中更新。 这可能会导致目标组织出现问题,例如 CODEOWNERS 文件未按预期工作。 有关如何预防并解决这些问题的详细信息,请参阅“使用 GitHub Enterprise Importer 排查迁移问题”。

存储库的迁移数据

直接或在组织迁移过程中迁移存储库时,只会迁移以下数据。

  • Git 源(包括提交历史记录)
  • 拉取请求
  • 问题
  • 里程碑
  • Wiki(不包括附件)
  • 存储库级别的项目(经典)
  • GitHub Actions 工作流程
  • 提交注释
  • 活动的 Webhook(必须在迁移后重新启用,请参阅“启用 Webhook”)
  • 仓库主题
  • 存储库设置
    • 分支保护(请参阅“分支保护”了解更多详细信息)
    • GitHub Pages 设置
    • 自动链接引用
    • GitHub Advanced Security 设置
    • 拉取请求设置
      • 自动删除头部分支
      • 允许自动合并
      • 允许合并提交(提交消息设置重置为默认消息)
      • 允许 squash 合并(提交消息设置重置为默认消息)
      • 允许变基合并
  • 发布(每个存储库最多 10 GB)
  • 上述数据的用户历史记录
  • 附件(请参阅“附加文件”)

目前,以下数据未迁移。

  • 任何 Projects(新项目体验)
  • Code scanning 结果
  • 提交状态检查
  • Dependabot 警报
  • Dependabot 机密
  • 存储库级别的讨论
  • 编辑议题注释和拉取请求注释的历史记录
  • 存储库之间的分支关系(请参阅“关于分叉”)
  • GitHub Actions 机密、变量、环境、自托管运行器、大型运行器 或工作流运行历史记录
  • GitHub Codespaces 机密
  • GitHub 应用和 GitHub 应用安装
  • Git LFS 对象和大型二进制文件(仍然支持使用 Git LFS 的存储库,请参阅“GitHub Enterprise Importer 的限制”)
  • GitHub Packages 中的包
  • 组织级别的项目(经典)
  • 不同存储库中拉取请求与问题之间的引用(请参阅“自动链接引用和 URL”)
  • secret scanning 结果的修正状态
  • 用户帐户拥有的存储库
  • 存储库属性(公共 beta 版)
  • 存储库星级
  • 存储库观察程序
  • 规则集
  • 标记保护规则
  • 用户配置文件、SSH 密钥、签名密钥或personal access tokens
  • Webhook 密码
  • 用户对存储库的访问权限

直接迁移存储库时,团队和团队对存储库的访问权限不会迁移。

分支保护

分支保护将一组指定的规则应用于特定分支名称或分支名称模式。 有关详细信息,请参阅“关于受保护分支”。

始终都会迁移分支保护,但不会迁移某些规则。 以下分支保护规则不会迁移。

  • 允许特定参与者绕过所需的拉取请求
  • 需要审批最近的推送
  • 在合并前要求部署成功
  • 锁定分支
  • 限制创建匹配分支的推送
  • 允许强制推送

还存在下列限制:

  • 如果分支保护规则可以选择性地用于指定不受该规则限制的人员、团队或应用(例如“限制可以关闭拉取请求评审的人员”),则不会迁移这些例外情况。
  • 如果在“指定可以进行强制推送的人员”模式下启用了“允许强制推送”规则,则不会迁移该规则。

迁移数据的限制

GitHub Enterprise Importer 可以迁移的内容存在限制。 有些是由于 GitHub.com 的限制,而另一些是由于 GitHub Enterprise Importer 本身的限制。

GitHub.com

的限制

  • 单个 Git 提交的大小限制为 2 GB:Git 存储库中的单个提交不能大于 2 GB。 如果有任何提交大于 2 GB,则需要将其拆分为较小的提交,使每个提交的大小不超过 2 GB。
  • Git 引用的限制为 255 字节:单个 Git 引用(通常称为“ref”)的名称不能大于 255 字节。 通常,这意味着引用的长度不能超过 255 个字符,但任何非 ASCII 字符(如表情符号)都可能占用多个字节。 如果任何 Git 引用太长,将返回明确的错误消息。
  • 文件大小限制为 100 MB:Git 存储库中的单个文件不能大于 100 MB。 请考虑使用 Git LFS 来存储大型文件。 有关详细信息,请参阅“管理大型文件”。

GitHub Enterprise Importer 的限制

  • Git 存储库的大小限制为 10 GB:此限制仅适用于源代码。 若要检查存储库存档是否超出限制,请使用 git-sizer 工具并查看输出中的 blob 总大小。 git-sizer 工具还有助于识别与大型文件、blob 大小、提交大小和可能影响迁移的树计数相关的潜在问题。
  • 元数据的限制为 10 GB:Importer 无法迁移元数据超过 10 GB 的存储库。 元数据包括问题、拉取请求、发布和附件。 在大多数情况下,大型元数据是由附加到发布的二进制资产引起的。 可以使用 migrate-repo 命令的 --skip-releases 标志从迁移中排除发布,然后在迁移后手动移动发布。
  • Git LFS 对象未迁移:Importer 可以迁移使用 Git LFS 的存储库,但不会迁移 LFS 对象本身。 迁移完成后,可以将其作为后续任务推送到迁移目标。 有关详细信息,请参阅“复制仓库”。
  • 所需后续任务:在 GitHub 产品之间迁移时,某些设置不会迁移,必须在新存储库中重新配置。 有关每次迁移后需要完成的后续任务的列表,请参阅“在 GitHub 产品之间迁移的概述”。
  • 延迟的代码搜索功能:迁移存储库后,重新编制搜索索引可能需要几个小时,在重新编制索引完成前,代码搜索可能会返回意外的结果。
  • 为组织配置的规则集可能会导致迁移失败:例如,如果配置的规则要求提交作者的电子邮件地址以 @monalisa.cat 结尾,而要迁移的存储库包含不符合此规则的提交,则迁移将失败。 有关规则集的详细信息,请参阅“关于规则集”。
  • 模特内容可能不可搜索:模特是与导入内容(如问题、拉取请求、注释等)关联的占位符用户。 搜索与模特关联的内容(如已分配的问题)时,可能找不到问题。 回收模特后,通过新所有者可找到内容。 有关详细信息,请参阅“回收 GitHub Enterprise Importer 的模型”。

使用入门

在 GitHub 产品之间迁移之前,应规划出如何开展迁移。 迁移数据之前,需要选择开展迁移的人。 必须向该人员授予迁移源和迁移目的地的所需访问权限。 我们还建议先开展测试迁移。

有关完整迁移过程的概述,请参阅“在 GitHub 产品之间迁移的概述”。