跳至主要内容

使用 GitHub Actions 导入程序从 Bitbucket Pipelines 迁移

了解如何使用 GitHub Actions 导入程序来自动化将 Bitbucket Pipelines 迁移到 GitHub Actions 的过程。

法律声明

关于使用 GitHub Actions 导入程序从 Bitbucket Pipelines 迁移

以下说明将指导您配置环境以使用 GitHub Actions 导入程序将 Bitbucket Pipelines 迁移到 GitHub Actions。

先决条件

  • 一个可以运行基于 Linux 的容器并可以安装必要工具的环境。

    注意

    GitHub Actions 导入程序容器和 CLI 不需要安装在与您的 CI 平台相同的服务器上。

限制

使用 GitHub Actions 导入程序将 Bitbucket Pipelines 迁移到 GitHub Actions 时存在一些限制。

  • 不支持私有 AWS ECR 中的镜像。

  • Bitbucket Pipelines 选项 size 不受支持。如果 GitHub Actions 中需要其他 Runner 资源,请考虑使用更大的 Runner。有关更多信息,请参阅“使用更大的 Runner”。

  • forecast 命令不支持详细说明作业队列时间的指标。

  • 可以使用 GitHub Actions 中的 always() 结合检查前一步的 steps.<step_id>.conclusion 来支持 Bitbucket after-scripts。有关更多信息,请参阅“访问有关工作流运行的上下文信息”。

    以下是使用 always()steps.<step_id>.conclusion 的示例。

      - name: After Script 1
        run: |-
          echo "I'm after the script ran!"
          echo "We should be grouped!"
        id: after-script-1
        if: "${{ always() }}"
      - name: After Script 2
        run: |-
          echo "this is really the end"
          echo "goodbye, for now!"
        id: after-script-2
        if: "${{ steps.after-script-1.conclusion == 'success' && always() }}"
    

手动任务

某些 Bitbucket Pipelines 结构必须手动迁移。其中包括

  • 安全存储库、工作区和部署变量
  • SSH 密钥

安装 GitHub Actions Importer CLI 扩展

  1. 安装 GitHub Actions Importer CLI 扩展

    Bash
    gh extension install github/gh-actions-importer
    
  2. 验证扩展是否已安装

    $ gh actions-importer -h
    Options:
      -?, -h, --help  Show help and usage information
    
    Commands:
      update     Update to the latest version of GitHub Actions Importer.
      version    Display the version of GitHub Actions Importer.
      configure  Start an interactive prompt to configure credentials used to authenticate with your CI server(s).
      audit      Plan your CI/CD migration by analyzing your current CI/CD footprint.
      forecast   Forecast GitHub Actions usage from historical pipeline utilization.
      dry-run    Convert a pipeline to a GitHub Actions workflow and output its yaml file.
      migrate    Convert a pipeline to a GitHub Actions workflow and open a pull request with the changes.
    

配置凭据

configure CLI 命令用于在使用 Bitbucket Pipelines 和 GitHub 时设置 GitHub Actions Importer 的必需凭据和选项。

  1. 创建一个 GitHub 个人访问令牌(经典版)。有关更多信息,请参阅“管理您的个人访问令牌”。

    您的令牌必须具有 workflow 范围。

    创建令牌后,复制它并将其保存在安全的位置以备后用。

  2. 为 Bitbucket Pipelines 创建工作区访问令牌。有关更多信息,请参阅 Bitbucket 文档中的 工作区访问令牌权限。您的令牌必须对管道、项目和存储库具有 read 范围。

  3. 在您的终端中,运行 GitHub Actions Importer configure CLI 命令

    gh actions-importer configure
    

    configure 命令将提示您输入以下信息

    • 对于“您要配置哪些 CI 提供商?”,使用箭头键选择 Bitbucket,按 Space 选择它,然后按 Enter
    • 对于“GitHub 的个人访问令牌”,输入您之前创建的个人访问令牌(经典版)的值,然后按 Enter
    • 对于“GitHub 实例的基本 URL”,按 Enter 接受默认值(https://github.com)。
    • 对于“Bitbucket 的个人访问令牌”,输入您之前创建的工作区访问令牌,然后按 Enter
    • 对于“Bitbucket 实例的基本 URL”,输入 Bitbucket 实例的 URL,然后按 Enter

    下面显示了 configure 命令的示例

    $ gh actions-importer configure
    ✔ Which CI providers are you configuring?: Bitbucket
    Enter the following values (leave empty to omit):
    ✔ Personal access token for GitHub: ***************
    ✔ Base url of the GitHub instance: https://github.com
    ✔ Personal access token for Bitbucket: ********************
    ✔ Base url of the Bitbucket instance: https://bitbucket.example.com
    Environment variables successfully updated.
    
  4. 在您的终端中,运行 GitHub Actions Importer update CLI 命令以连接到 GitHub Packages 容器注册表并确保容器映像更新到最新版本

    gh actions-importer update
    

    命令的输出应类似于以下内容

    Updating ghcr.io/actions-importer/cli:latest...
    ghcr.io/actions-importer/cli:latest up-to-date
    

执行 Bitbucket 实例的审计

您可以使用审计命令获取 Bitbucket 实例中管道的概览。

审计命令执行以下步骤。

  1. 获取工作区的所有管道。
  2. 将管道转换为等效的 GitHub Actions 工作流。
  3. 生成一份报告,总结使用 GitHub Actions Importer 可以实现的迁移的完整性和复杂性。

运行审计命令

要执行审计,请在您的终端中运行以下命令,将 :workspace 替换为要审计的 Bitbucket 工作区的名称。

gh actions-importer audit bitbucket --workspace :workspace --output-dir tmp/audit

可选地,可以向审计命令提供 --project-key 选项以将结果限制为仅与项目关联的管道。

在以下示例命令中,:project_key 应替换为要审计的项目的密钥。项目密钥可以在 Bitbucket 的工作区项目页面中找到。

gh actions-importer audit bitbucket --workspace :workspace --project-key :project_key --output-dir tmp/audit

检查审计结果

指定输出目录中的文件包含审计结果。请参阅 audit_summary.md 文件以获取审计结果的摘要。

审计摘要包含以下部分。

管道

“管道”部分包含有关 GitHub Actions Importer 完成的转换率的高级统计信息。

下面列出了一些可能出现在“管道”部分中的关键术语

  • 成功管道已将 100% 的管道结构和单个项目自动转换为其 GitHub Actions 等效项。
  • 部分成功管道已转换所有管道结构,但是,某些单个项目未自动转换为其 GitHub Actions 等效项。
  • 不支持的管道是 GitHub Actions Importer 不支持的定义类型。
  • 失败的管道在转换时遇到致命错误。这可能由于以下三个原因之一导致
    • 管道最初配置错误且无效。
    • GitHub Actions Importer 在转换时遇到内部错误。
    • 网络响应不成功导致管道无法访问,这通常是由于凭据无效导致的。

构建步骤

“构建步骤”部分概述了跨所有管道使用的单个构建步骤,以及 GitHub Actions Importer 自动转换了多少个构建步骤。

下面列出了一些可能出现在“构建步骤”部分中的关键术语

  • 已知构建步骤是指已自动转换为等效操作的步骤。
  • 未知构建步骤是指未自动转换为等效操作的步骤。
  • 不支持的构建步骤是指以下任一情况:
    • GitHub Actions 从根本上不支持。
    • 以与 GitHub Actions 不兼容的方式进行配置。
  • 操作是已转换工作流中使用的操作列表。这对于以下情况可能很重要:
    • 如果您使用 GitHub Enterprise Server,则收集要同步到您的实例的操作列表。
    • 定义组织级允许的操作列表。此操作列表是安全或合规团队可能需要审查的操作的综合列表。

手动任务

“手动任务”部分概述了 GitHub Actions Importer 无法自动完成的任务,您必须手动完成这些任务。

下面列出了一些可能出现在“手动任务”部分中的关键术语

  • 机密是在转换后的管道中使用的存储库或组织级机密。必须在 GitHub Actions 中手动创建这些机密才能使这些管道正常运行。有关更多信息,请参阅“在 GitHub Actions 中使用机密”。
  • 自托管运行器是指在转换后的管道中引用的运行器标签,该标签不是 GitHub 托管的运行器。您需要手动定义这些运行器才能使这些管道正常运行。

文件

审计报告的最后一部分提供了在审计期间写入磁盘的所有文件的清单。

每个管道文件都包含审计中包含的各种文件,包括

  • 在 GitHub 中定义的原始管道。
  • 用于转换管道的任何网络响应。
  • 转换后的工作流文件。
  • 可用于排查失败的管道转换的堆栈跟踪。

此外,workflow_usage.csv 文件包含每个成功转换的管道使用过的所有操作、机密和运行器的逗号分隔列表。这对于确定哪些工作流使用哪些操作、机密或运行器很有用,并且对于执行安全审查也很有用。

预测使用情况

您可以使用 forecast 命令通过计算 Bitbucket 实例中已完成的管道运行的指标来预测潜在的 GitHub Actions 使用情况。

运行预测命令

要执行潜在 GitHub Actions 使用情况的预测,请在您的终端中运行以下命令,将 :workspace 替换为要预测的 Bitbucket 工作区的名称。默认情况下,GitHub Actions Importer 会在预测报告中包含之前七天。

gh actions-importer forecast bitbucket --workspace :workspace --output-dir tmp/forecast_reports

预测项目

要将预测限制为某个项目,您可以使用 --project-key 选项。将 :project_key 的值替换为要预测的项目的项目密钥。

gh actions-importer forecast bitbucket --workspace :workspace --project-key :project_key --output-dir tmp/forecast_reports

检查预测报告

指定输出目录中的 forecast_report.md 文件包含预测结果。

下面列出了一些可能出现在预测报告中的一些关键术语

  • 作业数是已完成作业的总数。
  • 管道数是使用的唯一管道的数量。
  • 执行时间描述运行器在作业上花费的时间。此指标可用于帮助规划 GitHub 托管运行器的成本。
    • 此指标与您应该期望在 GitHub Actions 中花费的金额相关。这将根据这些分钟使用的硬件而有所不同。您可以使用 GitHub Actions 定价计算器 来估算成本。
  • 并发作业指标描述任何给定时间运行的作业数量。

执行模拟迁移

您可以使用模拟运行命令将 Bitbucket 管道转换为等效的 GitHub Actions 工作流。模拟运行会在指定的目录中创建输出文件,但不会打开拉取请求来迁移管道。

运行模拟运行命令

要执行将 Bitbucket 管道迁移到 GitHub Actions 的模拟运行,请在您的终端中运行以下命令,将 :workspace 替换为工作区的名称,将 :repo 替换为 Bitbucket 中存储库的名称。

gh actions-importer dry-run bitbucket --workspace :workspace --repository :repo --output-dir tmp/dry-run

检查转换后的工作流

您可以在指定的输出目录中查看模拟运行的日志和转换后的工作流文件。

如果 GitHub Actions Importer 无法自动转换任何内容,例如未知构建步骤或部分成功的管道,您可能需要创建自定义转换器以进一步自定义转换过程。有关更多信息,请参阅“使用自定义转换器扩展 GitHub Actions Importer”。

执行生产迁移

您可以使用迁移命令转换 Bitbucket 管道并打开包含等效 GitHub Actions 工作流的拉取请求。

运行 migrate 命令

要将 Bitbucket Pipeline 迁移到 GitHub Actions,请在您的终端中运行以下命令,并替换以下值。

  • target-url 值替换为 GitHub 存储库的 URL。
  • :repo 替换为 Bitbucket 中存储库的名称。
  • :workspace 替换为工作区的名称。
gh actions-importer migrate bitbucket --workspace :workspace --repository :repo --target-url https://github.com/:owner/:repo --output-dir tmp/dry-run

该命令的输出包括将转换后的工作流添加到您的存储库的拉取请求的 URL。成功输出的示例类似于以下内容

gh actions-importer migrate bitbucket --workspace actions-importer --repository custom-trigger --target-url https://github.com/valet-dev-testing/demo-private --output-dir tmp/bitbucket
[2023-07-18 09:56:06] Logs: 'tmp/bitbucket/log/valet-20230718-165606.log'
[2023-07-18 09:56:24] Pull request: 'https://github.com/valet-dev-testing/demo-private/pull/55'

检查拉取请求

成功运行 migrate 命令的输出包含一个链接,指向将转换后的工作流添加到您的存储库的新拉取请求。

拉取请求的一些重要元素包括

  • 在拉取请求描述中,一个名为**手动步骤**的部分,其中列出了在完成将管道迁移到 GitHub Actions 之前必须手动完成的步骤。例如,此部分可能会告诉您创建工作流中使用的任何密钥。
  • 转换后的工作流文件。选择拉取请求中的**已更改的文件**选项卡以查看将添加到您的 GitHub 存储库的工作流文件。

完成检查拉取请求后,您可以将其合并以将工作流添加到您的 GitHub 存储库。

参考

本节包含有关使用 GitHub Actions Importer 从 Bitbucket Pipelines 迁移时环境变量、可选参数和支持的语法的参考信息。

使用环境变量

GitHub Actions Importer 使用环境变量进行身份验证配置。这些变量在使用 configure 命令遵循配置过程时设置。有关更多信息,请参阅“配置凭据”部分。

GitHub Actions Importer 使用以下环境变量连接到您的 Bitbucket 实例。

  • GITHUB_ACCESS_TOKEN:用于使用转换后的工作流创建拉取请求的个人访问令牌(经典)(需要 repoworkflow 范围)。
  • GITHUB_INSTANCE_URL:目标 GitHub 实例的 URL。(例如 https://github.com
  • BITBUCKET_ACCESS_TOKEN:具有管道、项目和存储库读取范围的工作区访问令牌。

这些环境变量可以在 .env.local 文件中指定,该文件将在运行时由 GitHub Actions Importer 加载。分发存档包含一个 .env.local.template 文件,可用于创建这些文件。

可选参数

您可以使用 GitHub Actions Importer 子命令的可选参数来自定义迁移。

--source-file-path

您可以将 --source-file-path 参数与 dry-runmigrate 子命令一起使用。

默认情况下,GitHub Actions Importer 从 Bitbucket 实例获取管道内容。--source-file-path 参数告诉 GitHub Actions Importer 使用指定的源文件路径。

例如

gh actions-importer dry-run bitbucket --workspace :workspace --repository :repo --output-dir tmp/dry-run --source-file-path path/to/my/pipeline/file.yml

--config-file-path

您可以将 --config-file-path 参数与 auditdry-runmigrate 子命令一起使用。

默认情况下,GitHub Actions Importer 从 Bitbucket 实例获取管道内容。--config-file-path 参数告诉 GitHub Actions Importer 使用指定的源文件。

审计示例

在此示例中,GitHub Actions Importer 使用指定的 YAML 配置文件执行审计。

gh actions-importer audit bitbucket --workspace :workspace --output-dir tmp/audit --config-file-path "path/to/my/bitbucket/config.yml"

要使用配置文件审计 Bitbucket 实例,配置文件必须采用以下格式,并且每个 repository_slug 必须唯一

source_files:
  - repository_slug: repo_name
    path: path/to/one/source/file.yml
  - repository_slug: another_repo_name
    path: path/to/another/source/file.yml

Bitbucket Pipelines 的支持语法

下表显示了 GitHub Actions Importer 当前能够转换的属性类型。

BitbucketGitHub Actions状态
after-scriptjobs.<job_id>.steps[*]支持
artifactsactions/upload-artifact & download-artifact支持
cachesactions/cache支持
cloneactions/checkout支持
conditionjob.<job_id>.steps[*].run支持
deploymentjobs.<job_id>.environment支持
imagejobs.<job_id>.container支持
max-timejobs.<job_id>.steps[*].timeout-minutes支持
options.docker支持
options.max-timejobs.<job_id>.steps[*].timeout-minutes支持
paralleljobs.<job_id>支持
pipelines.brancheson.push支持
pipelines.customon.workflow_dispatch支持
pipelines.defaulton.push支持
pipelines.pull-requestson.pull_requests支持
pipelines.tagson.tags支持
runs-onjobs.<job_id>.runs-on支持
scriptjob.<job_id>.steps[*].run支持
servicesjobs.<job_id>.service支持
stagejobs.<job_id>支持
stepjobs.<job_id>.steps[*]支持
triggeron.workflow_dispatch支持
fail-fast不支持
oidc不支持
options.size不支持
size不支持

环境变量映射

GitHub Actions Importer 使用下表中的映射将默认 Bitbucket 环境变量转换为 GitHub Actions 中最接近的等效项。

BitbucketGitHub Actions
CItrue
BITBUCKET_BUILD_NUMBER${{ github.run_number }}
BITBUCKET_CLONE_DIR${{ github.workspace }}
BITBUCKET_COMMIT${{ github.sha }}
BITBUCKET_WORKSPACE${{ github.repository_owner }}
BITBUCKET_REPO_SLUG${{ github.repository }}
BITBUCKET_REPO_UUID${{ github.repository_id }}
BITBUCKET_REPO_FULL_NAME${{ github.repository_owner }}/${{ github.repository }}
BITBUCKET_BRANCH${{ github.ref }}
BITBUCKET_TAG${{ github.ref }}
BITBUCKET_PR_ID${{ github.event.pull_request.number }}
BITBUCKET_PR_DESTINATION_BRANCH${{ github.event.pull_request.base.ref }}
BITBUCKET_GIT_HTTP_ORIGIN${{ github.event.repository.clone_url }}
BITBUCKET_GIT_SSH_ORIGIN${{ github.event.repository.ssh_url }}
BITBUCKET_EXIT_CODE${{ job.status }}
BITBUCKET_STEP_UUID${{ job.github_job }}
BITBUCKET_PIPELINE_UUID${{ github.workflow }}
BITBUCKET_PROJECT_KEY${{ github.repository_owner }}
BITBUCKET_PROJECT_UUID${{ github.repository_owner }}
BITBUCKET_STEP_TRIGGERER_UUID${{ github.actor_id }}
BITBUCKET_SSH_KEY_FILE${{ github.workspace }}/.ssh/id_rsa
BITBUCKET_STEP_OIDC_TOKEN无映射
BITBUCKET_DEPLOYMENT_ENVIRONMENT无映射
BITBUCKET_DEPLOYMENT_ENVIRONMENT_UUID无映射
BITBUCKET_BOOKMARK无映射
BITBUCKET_PARALLEL_STEP无映射
BITBUCKET_PARALLEL_STEP_COUNT无映射

系统变量

任务中使用的系统变量将转换为等效的 bash shell 变量,并假定可用。例如,${system.<variable.name>} 将转换为 $variable_name。我们建议您验证这一点,以确保工作流的正常运行。

部分内容已从 https://github.com/github/gh-actions-importer/(根据 MIT 许可证)改编而来

MIT License

Copyright (c) 2022 GitHub

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.