您可以为存储库的特定分支设置预构建配置。
从启用了预构建的基础分支创建的任何分支通常也会在代码空间创建期间分配一个预构建。 如果分支上的开发容器与基本分支上的开发容器相同,则会出现这种情况。 这是因为具有相同开发容器配置的分支的大多数预构建配置都相同,因此开发人员也可以从这些分支上更快的代码空间创建时间中受益。 更多信息请参阅“开发容器简介”。
通常,在为分支配置预构建时,预构建将可用于该分支的 Codespaces 计算机类型。 但是,如果存储库大于 32 GB,则预构建将不适用于 2 核和 4 核计算机类型,因为它们提供的存储限制为 32 GB。
如果在创建代码空间时选择使用 .devcontainer/SUBDIRECTORY
位置的 devcontainer.json
文件,则预构建不可用。 有关选择 devcontainer.json
文件的信息,请参阅“创建代码空间”。
基本要求
在为项目配置预构建之前,必须满足以下条件:
- 必须为您的组织启用 GitHub Codespaces。 更多信息请参阅“为组织启用 Codespaces”。
- 必须为您的仓库启用 GitHub Actions。 每个预构建配置都需要能够触发关联的操作工作流程。 更多信息请参阅“管理仓库的 GitHub Actions 设置”。
配置预构建
-
在 GitHub.com 上,导航到仓库的主页面。
-
在仓库名称下,单击 Settings(设置)。
-
在边栏的“Code & automation(代码和自动化)”部分中,单击 Codespaces。
-
在“Prebuild configuration(预构建配置)”下,单击 Set up prebuild(设置预构建)。
-
选择要为其设置预构建的分支。
注意:从启用了预构建的基本分支创建的任何分支通常也会获得预构建。 例如,如果为存储库的默认分支启用预构建,则在大多数情况下,基于默认分支的分支也将获得预构建。
-
选择自动触发预构建模板更新的方式。
- 每次推送(默认设置)- 使用此设置,每次推送到给定分支时,都会更新预构建配置。 这将确保从预构建模板生成的代码空间始终包含最新的代码空间配置,包括任何最近添加或更新的依赖项。
- 在配置更改时 - 使用此设置,每次更新给定存储库和分支的关联配置文件时,都会更新预构建配置。 这可确保在从预构建模板生成代码空间时使用对存储库的开发容器配置文件所做的更改。 更新预构建模板的 Actions 工作流程的运行频率较低,因此此选项将使用较少的 Actions 分钟数。 但是,此选项不保证代码空间始终包含最近添加或更新的依赖项,因此在创建代码空间后,可能必须手动添加或更新这些依赖项。
- 计划 - 使用此设置,您可以按照自己定义的自定义计划更新预构建配置。 这可以减少操作分钟数的消耗,但是,使用此选项,可以创建不使用最新开发容器配置更改的代码空间。
-
选择 Reduce prebuild available to only specific regions(减少仅对特定区域可用的预构建)以限制对预构建映像的访问,然后选择希望其在哪些区域可用。 开发人员只能从预构建创建代码空间(如果它们位于所选区域中)。 默认情况下,预构建的映像可用于代码空间可用的所有区域,并且每个区域都适用存储成本。
注意:
- 每个区域的预构建模板将产生单独的费用。 因此,您应仅为已知将使用预构建的区域启用预构建。 更多信息请参阅“关于 Codespaces 预构建”。
- 开发人员可以为 Codespaces 设置其默认区域,这样您就可以为较少的区域启用预构建。 有关详细信息,请参阅“设置 Codespaces 的默认区域”。
-
设置要保留的预构建模板版本数。 您可以输入 1 到 5 之间的任意数字。 保存版本的默认数量为 2,这意味着仅保存最新的模板版本和以前的版本。
根据预构建触发器设置,预构建模板可能会随每次推送或每次开发容器配置更改而更改。 通过保留旧版本的预构建模板,可以从较旧的提交创建预构建,其开发容器配置与当前预构建模板不同。 由于保留预构建模板版本会产生相关的存储成本,因此您可以根据团队的需求选择要保留的版本数。 有关计费的更多信息,请参阅“关于 Codespaces 的计费”。
如果要保存的预构建模板版本数设置为 1,Codespaces 将仅保存预构建模板的最新版本,并在每次更新模板时删除旧版本。 这意味着,如果返回到较旧的开发容器配置,则不会获得预构建的代码空间。
-
添加用户或团队,以便在此配置的预构建工作流程运行失败时发出通知。 您可以开始键入用户名、团队名称或全名,然后在出现名称后点按该名称以将其添加到列表中。 发生预构建失败时,您添加的用户或团队将收到一封电子邮件,其中包含指向工作流程运行日志的链接,以帮助进一步调查。
-
单击 Create(创建)。
预构建配置列在存储库设置的 Codespaces 页面上。 GitHub Actions 工作流程将排队,然后运行以根据您选择的分支在指定的区域中创建预构建模板。
注意:默认情况下,预构建配置的 GitHub Actions 工作流程只能访问其自己的存储库中的资源。 如果您的项目使用存储库外部的资源,则需要设置
CODESPACES_PREBUILD_TOKEN
密钥以授予所需的访问权限。 更多信息请参阅“允许预构建访问外部资源”。
配置对不在存储库中的资源的访问
默认情况下,预构建配置的 GitHub Actions 工作流程只能访问其自己的存储库内容。 如果项目需要访问外部资源来构建开发环境,则需要设置具有相应访问范围的个人访问令牌 (PAT)。
更多信息请参阅“允许预构建访问外部资源”。
配置环境变量
要允许预构建过程访问创建开发环境所需的环境变量,您可以将这些变量设置为 Codespaces 存储库机密或 Codespaces 组织机密。 更多信息请参阅“为存储库添加机密”和“为组织添加机密”。
预构建在构建环境时不使用任何用户级机密,因为在创建代码空间之前不会添加这些机密。
以这种方式创建的 Codespaces 机密将由从此存储库创建代码空间的任何人都可以访问。 如果您不希望这样做,也可以设置 CODESPACES_PREBUILD_TOKEN
密钥。 CODESPACES_PREBUILD_TOKEN
密钥仅用于预构建,其值在用户的代码空间中不可访问。 更多信息请参阅“允许预构建访问外部资源”。
配置要包含在预构建中的耗时任务
您可以在 devcontainer.json
中使用 onCreateCommand
和 updateContentCommand
命令,以将耗时的过程作为预构建模板创建的一部分包括在内。 更多信息请参阅 Visual Studio Code 文档“devcontainer.json 参考”。
onCreateCommand
仅在创建预构建模板时运行一次,而 updateContentCommand
在模板创建和后续模板更新时运行。 增量构建应包含在 updateContentCommand
中,因为它们表示项目的源代码,并且需要包含在每个预构建模板更新中。
延伸阅读
- “预构建疑难解答”