从 Bitbucket 数据中心构建代码库

借助 Cloud Build,您可以创建用于构建作业的触发器 或 Cloud Shell Bitbucket 数据中心、 让您可以执行构建来响应各种事件,例如提交推送或 与 Bitbucket Data Center 代码库关联的拉取请求。

本页面介绍如何在 Bitbucket 数据中心实例上启用触发器功能。

准备工作

  • Enable the Cloud Build, Secret Manager, and Compute Engine APIs.

    Enable the APIs

创建 Bitbucket Data Center 触发器

本部分介绍如何将您的 Bitbucket 数据中心代码库关联到 Cloud Build,以及如何创建触发器以自动在关联的代码库上调用构建。如果要在专用网络中使用 Bitbucket 数据中心触发器,请参阅在专用网络中从 Bitbucket 数据中心构建代码库,了解更多说明。

控制台

如需使用 Google Cloud 控制台创建 Bitbucket Data Center 触发器,请执行以下操作:

  1. 打开触发器页面

    打开“触发器”页面

  2. 从页面顶部选择您的项目,然后点击打开

  3. 点击创建触发器

  4. 输入以下触发器设置:

    • 名称:触发器的名称。

    • 区域:为触发器选择区域

      • 如果您选择全球作为区域, Cloud Build 使用 运行 build。
      • 如果您选择非全球区域,并且与触发器关联的 build 配置文件指定了专用池,Cloud Build 将使用该专用池运行 build。在这种情况下,您在触发器中指定的区域必须与创建专用池的区域一致。
      • 如果您选择非全球区域,并且与触发器关联的构建配置文件指定专用池,Cloud Build 会使用默认池在与触发器相同的区域中运行您的构建。
    • 说明(可选):触发器的说明。

    • 事件:选择用于调用触发器的代码库事件。

      • 推送到分支:设置触发器,以便基于对特定分支的提交启动构建。

      • 推送新标记:将触发器设置为以基于包含特定标记的提交启动构建。

      • 拉取请求:设置触发器以启动构建 拉取请求的提交

    • 来源:选择第 1 代作为来源。

      • 代码库:从可用代码库列表中,选择一个 存储库如需关联新的代码库,请参阅关联到 Bitbucket 数据中心代码库

      • 分支标记:指定包含分支或 标记值相匹配。

      • 评论控制:如果您选择了 Pull request 作为活动时,请选择下列选项之一, 控制构建是否由触发器自动执行:

      • 必需(所有者和协作者除外):代码库所有者或协作者创建或更新拉取请求后,触发器会自动执行构建。如果外部贡献者发起操作,则只有在所有者或协作者对拉取请求中的 /gcbrun 添加注释之后,触发器才会执行构建。

      • 必需:任何贡献者创建或更新拉取请求后,只有在所有者或协作者对拉取请求中的 /gcbrun 添加注释之后,触发器才会执行构建。build 都会在系统每次更改拉取请求时执行。

      • 不需要:任何贡献者创建或更新拉取请求后,触发器将自动执行构建。

    • 配置:选择位于您的代码库中的构建配置文件,或在触发器上以内嵌方式配置构建。

    • 类型:选择要用于构建的配置类型。

      • Cloud Build 配置文件(yaml 或 json):为您的配置使用构建配置文件。
      • Dockerfile:为您的配置使用 Dockerfile
    • 位置:为您的配置指定位置。

      • 代码库:如果您的配置文件位于 请提供您的 构建配置文件Dockerfile 目录和所生成映像的名称。如果您的配置是 Dockerfile,则还可以选择提供构建的超时时间。提供了 Dockerfile 和映像名称后,您会看到构建将执行的 docker build 命令的预览。

      • 内嵌:如果您选择了 Cloud Build 配置文件(yaml 或 json)作为配置选项,则可以指定内嵌构建配置。点击 Open Editor(打开编辑器),在 使用 YAML 或 JSON 语法创建 Google Cloud 控制台。点击完成以保存您的构建配置。

  5. 点击创建以创建 Bitbucket 数据中心触发器。

gcloud

如需使用 gcloud 命令创建 Bitbucket 数据中心触发器,您需要在终端中运行以下 gcloud builds triggers create bitbucketserver 命令:

gcloud builds triggers create bitbucketserver
--name=TRIGGER_NAME \
--project-key=PROJECT_KEY \
--repo-slug=REPO_SLUG \
--bitbucket-server-config-resource=projects/PROJECT_NUMBER/locations/REGION/bitbucketServerConfigs/ID \
--branch-pattern=BRANCH_NAME \ # --tag-pattern=TAG_NAME
--build-config=BUILD_CONFIG

其中:

  • TRIGGER_NAME 是触发器的名称。
  • PROJECT_KEY 是您的 Bitbucket 数据中心项目的密钥。
  • REPO_SLUG 是您的 Bitbucket 数据中心代码库的 slug
  • PROJECT_NUMBER 是您的 Google Cloud 项目。
  • REGION 是与您的 Bitbucket 数据中心配置关联的区域
  • ID 是您的 BitbucketServerConfig 的 ID。
  • 如果您要设置您的触发器来构建特定分支,则 BRANCH_NAME 是与您的分支匹配的正则表达式。
  • 如果您要设置您的触发器来构建特定标记,则 TAG_NAME 是与您的标记匹配的正则表达式。
  • BUILD_CONFIG 是构建配置文件的路径。

API

如需使用 API 创建 Bitbucket 数据中心触发器,请使用以下 JSON 模板。

{
  "filename": "cloudbuild.yaml",
  "name": "curl-trigger",
  "description": "curl trigger",
  "bitbucket_server_trigger_config": {
      "repo_slug": "REPO_SLUG",
      "project_key": "PROJECT_KEY",
      "push": {
          "branch": "BRANCH_NAME" # "tag": "TAG_NAME"
      },
      "bitbucket_server_config_resource": "projects/PROJECT_NUMBER/locations/REGION/bitbucketServerConfigs/ID"
  }
}

其中:

  • REPO_SLUG 是您的 Bitbucket 数据中心代码库的 slug
  • PROJECT_KEY 是您的 Bitbucket 数据中心项目的密钥。
  • BRANCH_NAME 是与以下内容匹配的正则表达式: 如果要将触发器设置为构建特定分支,请使用您的分支。
  • TAG_NAME 是与您的搜索条件 代码。
  • PROJECT_NUMBER 是您的 Google Cloud 项目的项目编号。
  • REGION区域 与 Bitbucket Data Center 配置关联的政策
  • ID 是您的 BitbucketServerConfig 的 ID。

在终端中输入以下 curl 命令,其中 PROJECT_ID 是您的 Google Cloud 项目 ID:

curl -X POST -H "Authorization: Bearer "$(gcloud auth print-access-token) -H "Content-Type: application/json; charset=utf-8" https://cloudbuild.googleapis.com/v1/projects/PROJECT_ID/triggers -d @trigger.json

数据共享

从 Cloud Build 发送到 Bitbucket 数据中心的数据有助于您识别触发器 并查看您的 Bitbucket Data Center 代码库的构建结果。

Cloud Build 和 Bitbucket 数据中心主机之间会共享以下数据:

  • Google Cloud 项目 ID
  • 触发器名称

系统会自动为 Bitbucket Data Center 启用数据共享。

后续步骤