创建标准代码库

本页面介绍如何创建 Artifact Registry 标准代码库。

标准代码库是您的私有工件的代码库。您可以将工件上传至这些代码库并直接从这些代码库中下载工件。

还有两种存储库模式可用于某些工件格式:

  • 远程存储来自 Docker Hub、Maven Central 或 PyPI 等外部来源的工件。
  • Virtual 可作为下载、安装和部署上游标准代码库中或远程代码库中的工件的单一访问点。

每个代码库可以包含一种支持的格式的工件。

准备工作

  1. 启用 Artifact Registry,包括启用 Artifact Registry API 和安装 Google Cloud CLI。
  2. (可选)为 gcloud 命令配置默认值
  3. 如果您要求使用客户管理的加密密钥 (CMEK) 来加密代码库内容,请在 Cloud KMS 中为代码库创建和启用密钥。

所需的角色

如需获取创建代码库所需的权限,请让管理员向您授予 Google Cloud 项目的 Artifact Registry Repository Administrator (roles/artifactregistry.repoAdmin) IAM 角色。如需详细了解如何授予角色,请参阅管理访问权限

您也可以通过自定义角色或其他预定义角色来获取所需的权限。

创建标准代码库

创建代码库时,您必须配置以下设置,并且在代码库创建后无法更改:

  • 工件格式。
  • 仓库模式(如果多种模式适用于所选格式)。
  • 代码库位置
  • 使用 Google 管理的密钥或客户管理的加密密钥进行加密。Artifact Registry 默认使用 Google 管理的加密密钥。

Artifact Registry 会强制执行组织政策限制条件,要求 CMEK 来加密资源或限制哪些 Cloud KMS 密钥可用于 CMEK 保护。

使用 Google Cloud 控制台创建代码库

  1. 打开 Google Cloud 控制台中的制品库页面。

    打开“代码库”页面

  2. 点击创建代码库

  3. 指定代码库名称。对于项目中的每个代码库位置,代码库名称必须是唯一的。

  4. 选择代码库格式。

  5. 如果多种仓库模式可用,请选择 Standard

  6. Maven only:配置版本政策。

    1. 选择版本政策:

      • - 无版本政策。存储发布软件包和快照软件包。
      • 发布 - 仅存储发布包。
      • 快照 - 仅存储快照软件包。
    2. 如果您希望快照代码库接受覆盖代码库中现有版本的非唯一快照,请选择允许快照覆盖

  7. 位置类型下,选择代码库的位置:

    1. 选择位置类型:“单区域”或“多区域”。位置列表会更改,以反映您的选择。

    2. 区域多区域列表中,选择一个位置。

    如需了解位置类型和支持的位置,请参阅代码库位置

  8. 为代码库添加说明。说明有助于确定代码库的用途及其包含的工件类型。

    请勿包含敏感数据,因为代码库说明未加密。

  9. 如果要使用标签来整理代码库,请点击添加标签,然后输入标签的键值对。您可以在创建代码库后添加、修改或移除标签。

  10. 加密部分中,选择代码库的加密机制。

    • Google 管理的密钥 - 使用 Google 管理的加密密钥来加密代码库内容。
    • 客户管理的密钥 - 使用您通过 Cloud Key Management Service 控制的密钥来加密代码库内容。如需查看密钥设置说明,请参阅为代码库设置 CMEK

    • 对于 Docker 代码库,不可变映像标记设置(预览版)会将代码库配置为使用始终指向同一映像摘要的映像标记。拥有 Artifact Registry 管理员角色的用户可以在创建代码库后更改此设置。

      • 默认情况下,此设置处于停用状态。映像标记是可变的,这意味着该标记指向的映像摘要可能会发生变化。
      • 启用此设置后,图片代码不可更改。标记必须始终指向同一映像摘要。 如需详细了解可变和不可变的映像标记,请参阅容器映像版本
  11. 点击创建

Artifact Registry 会创建代码库并将其添加到代码库列表中。

创建代码库后,请执行以下操作:

使用 Google Cloud CLI 创建代码库

运行该命令以创建新的代码库。

公寓

gcloud artifacts repositories create REPOSITORY \
    --repository-format=apt \
    --location=LOCATION \
    --description="DESCRIPTION" \
    --kms-key=KMS-KEY \
    --async
  • REPOSITORY 是代码库的名称。对于项目中的每个代码库位置,代码库名称不得重复。
  • LOCATION 是代码库的单区域或多区域位置。如果您设置默认值,则可以省略此标志。如需查看受支持位置的列表,请运行以下命令:

    gcloud artifacts locations list
    
  • DESCRIPTION 是代码库的说明。请勿包含敏感数据,因为代码库说明未加密。

  • KMS-KEY 是 Cloud KMS 加密密钥的完整路径(如果您使用客户管理的加密密钥来加密代码库内容的话)。路径的格式为:

    projects/KMS-PROJECT/locations/KMS-LOCATION/keyRings/KEY-RING/cryptoKeys/KEY
    

    地点

    • KMS-PROJECT 是存储密钥的项目。
    • KMS-LOCATION 是密钥的位置。
    • KEY-RING 是密钥环的名称。
    • KEY 是密钥的名称。
  • --async 会立即返回结果,而无需等待正在进行的操作完成。

Docker

gcloud artifacts repositories create REPOSITORY \
    --repository-format=docker \
    --location=LOCATION \
    --description="DESCRIPTION" \
    --kms-key=KMS-KEY \
    --immutable-tags \
    --async
  • REPOSITORY 是代码库的名称。对于项目中的每个代码库位置,代码库名称不得重复。
  • LOCATION 是代码库的单区域或多区域位置。如果您设置默认值,则可以省略此标志。如需查看受支持位置的列表,请运行以下命令:

    gcloud artifacts locations list
    
  • DESCRIPTION 是代码库的说明。请勿包含敏感数据,因为代码库说明未加密。

  • KMS-KEY 是 Cloud KMS 加密密钥的完整路径(如果您使用客户管理的加密密钥来加密代码库内容的话)。路径的格式为:

    projects/KMS-PROJECT/locations/KMS-LOCATION/keyRings/KEY-RING/cryptoKeys/KEY
    

    地点

    • KMS-PROJECT 是存储密钥的项目。
    • KMS-LOCATION 是密钥的位置。
    • KEY-RING 是密钥环的名称。
    • KEY 是密钥的名称。
  • --immutable-tags 是一个可选标志,用于将代码库配置为使用始终指向同一映像摘要的标记。

    默认情况下,如果未传递 --immutable-tags 标志,则可以将标记移至其他映像摘要。如需详细了解不可变和可变的映像标记,请参阅容器映像版本

  • --async 会立即返回结果,而无需等待正在进行的操作完成。

KubeFlow 流水线

gcloud artifacts repositories create REPOSITORY \
    --repository-format=kfp \
    --location=LOCATION \
    --description="DESCRIPTION" \
    --kms-key=KMS-KEY \
    --async
  • REPOSITORY 是代码库的名称。对于项目中的每个代码库位置,代码库名称不得重复。
  • LOCATION 是代码库的单区域或多区域位置。如果您设置默认值,则可以省略此标志。如需查看受支持位置的列表,请运行以下命令:

    gcloud artifacts locations list
    
  • DESCRIPTION 是代码库的说明。请勿包含敏感数据,因为代码库说明未加密。

  • KMS-KEY 是 Cloud KMS 加密密钥的完整路径(如果您使用客户管理的加密密钥来加密代码库内容的话)。路径的格式为:

    projects/KMS-PROJECT/locations/KMS-LOCATION/keyRings/KEY-RING/cryptoKeys/KEY
    

    地点

    • KMS-PROJECT 是存储密钥的项目。
    • KMS-LOCATION 是密钥的位置。
    • KEY-RING 是密钥环的名称。
    • KEY 是密钥的名称。
  • --async 会立即返回结果,而无需等待正在进行的操作完成。

Maven

默认情况下,Maven 制品库会存储软件包的快照和发布版本。您可以指定版本政策来创建快照或发布代码库。

如需创建用于存储快照和版本的代码库,请运行以下命令:

gcloud artifacts repositories create REPOSITORY \
    --repository-format=maven \
    --location=LOCATION \
    --description="DESCRIPTION" \
    --kms-key=KMS-KEY \
    --async
  • REPOSITORY 是代码库的名称。对于项目中的每个代码库位置,代码库名称不得重复。
  • LOCATION 是代码库的单区域或多区域位置。如果您设置默认值,则可以省略此标志。如需查看受支持位置的列表,请运行以下命令:

    gcloud artifacts locations list
    
  • DESCRIPTION 是代码库的说明。请勿包含敏感数据,因为代码库说明未加密。

  • KMS-KEY 是 Cloud KMS 加密密钥的完整路径(如果您使用客户管理的加密密钥来加密代码库内容的话)。路径的格式为:

    projects/KMS-PROJECT/locations/KMS-LOCATION/keyRings/KEY-RING/cryptoKeys/KEY
    

    地点

    • KMS-PROJECT 是存储密钥的项目。
    • KMS-LOCATION 是密钥的位置。
    • KEY-RING 是密钥环的名称。
    • KEY 是密钥的名称。
  • --async 会立即返回结果,而无需等待正在进行的操作完成。

如需在不同的代码库中存储快照和发布版本,请在命令中指定版本政策:

gcloud artifacts repositories create REPOSITORY \
  --repository-format=maven \
  [--location=LOCATION] \
  [--description="DESCRIPTION"] \
  [--kms-key=KMS-KEY] \
  [--version-policy=VERSION-POLICY] \
  [--allow-snapshot-overwrites] \
  [--async] \

以下标志特定于 Maven 代码库:

--version-policy=VERSION-POLICY
指定要存储在代码库中的软件包类型。您可以将 VERSION-POLICY 设置为
  • None - 无版本政策。存储发布软件包和快照软件包。 如果您未在命令中添加 --version-policy 标志,则此为默认设置。
  • Release - 仅存储发布版软件包。
  • Snapshot - 仅存储快照软件包。
--allow-snapshot-overwrites
仅适用于快照代码库。如果指定此标志,您可以发布非唯一快照,以覆盖代码库中的现有版本。

npm

gcloud artifacts repositories create REPOSITORY \
    --repository-format=npm \
    --location=LOCATION \
    --description="DESCRIPTION" \
    --kms-key=KMS-KEY \
    --async
  • REPOSITORY 是代码库的名称。对于项目中的每个代码库位置,代码库名称不得重复。
  • LOCATION 是代码库的单区域或多区域位置。如果您设置默认值,则可以省略此标志。如需查看受支持位置的列表,请运行以下命令:

    gcloud artifacts locations list
    
  • DESCRIPTION 是代码库的说明。请勿包含敏感数据,因为代码库说明未加密。

  • KMS-KEY 是 Cloud KMS 加密密钥的完整路径(如果您使用客户管理的加密密钥来加密代码库内容的话)。路径的格式为:

    projects/KMS-PROJECT/locations/KMS-LOCATION/keyRings/KEY-RING/cryptoKeys/KEY
    

    地点

    • KMS-PROJECT 是存储密钥的项目。
    • KMS-LOCATION 是密钥的位置。
    • KEY-RING 是密钥环的名称。
    • KEY 是密钥的名称。
  • --async 会立即返回结果,而无需等待正在进行的操作完成。

Python

gcloud artifacts repositories create REPOSITORY \
    --repository-format=python \
    --location=LOCATION \
    --description="DESCRIPTION" \
    --kms-key=KMS-KEY \
    --async
  • REPOSITORY 是代码库的名称。对于项目中的每个代码库位置,代码库名称不得重复。
  • LOCATION 是代码库的单区域或多区域位置。如果您设置默认值,则可以省略此标志。如需查看受支持位置的列表,请运行以下命令:

    gcloud artifacts locations list
    
  • DESCRIPTION 是代码库的说明。请勿包含敏感数据,因为代码库说明未加密。

  • KMS-KEY 是 Cloud KMS 加密密钥的完整路径(如果您使用客户管理的加密密钥来加密代码库内容的话)。路径的格式为:

    projects/KMS-PROJECT/locations/KMS-LOCATION/keyRings/KEY-RING/cryptoKeys/KEY
    

    地点

    • KMS-PROJECT 是存储密钥的项目。
    • KMS-LOCATION 是密钥的位置。
    • KEY-RING 是密钥环的名称。
    • KEY 是密钥的名称。
  • --async 会立即返回结果,而无需等待正在进行的操作完成。

甜蜜

gcloud artifacts repositories create REPOSITORY \
    --repository-format=yum \
    --location=LOCATION \
    --description="DESCRIPTION" \
    --kms-key=KMS-KEY \
    --async
  • REPOSITORY 是代码库的名称。对于项目中的每个代码库位置,代码库名称不得重复。
  • LOCATION 是代码库的单区域或多区域位置。如果您设置默认值,则可以省略此标志。如需查看受支持位置的列表,请运行以下命令:

    gcloud artifacts locations list
    
  • DESCRIPTION 是代码库的说明。请勿包含敏感数据,因为代码库说明未加密。

  • KMS-KEY 是 Cloud KMS 加密密钥的完整路径(如果您使用客户管理的加密密钥来加密代码库内容的话)。路径的格式为:

    projects/KMS-PROJECT/locations/KMS-LOCATION/keyRings/KEY-RING/cryptoKeys/KEY
    

    地点

    • KMS-PROJECT 是存储密钥的项目。
    • KMS-LOCATION 是密钥的位置。
    • KEY-RING 是密钥环的名称。
    • KEY 是密钥的名称。
  • --async 会立即返回结果,而无需等待正在进行的操作完成。

Go

gcloud artifacts repositories create REPOSITORY \
    --repository-format=go \
    --location=LOCATION \
    --description="DESCRIPTION" \
    --kms-key=KMS-KEY \
    --async
  • REPOSITORY 是代码库的名称。对于项目中的每个代码库位置,代码库名称不得重复。
  • LOCATION 是代码库的单区域或多区域位置。如果您设置默认值,则可以省略此标志。如需查看受支持位置的列表,请运行以下命令:

    gcloud artifacts locations list
    
  • DESCRIPTION 是代码库的说明。请勿包含敏感数据,因为代码库说明未加密。

  • KMS-KEY 是 Cloud KMS 加密密钥的完整路径(如果您使用客户管理的加密密钥来加密代码库内容的话)。路径的格式为:

    projects/KMS-PROJECT/locations/KMS-LOCATION/keyRings/KEY-RING/cryptoKeys/KEY
    

    地点

    • KMS-PROJECT 是存储密钥的项目。
    • KMS-LOCATION 是密钥的位置。
    • KEY-RING 是密钥环的名称。
    • KEY 是密钥的名称。
  • --async 会立即返回结果,而无需等待正在进行的操作完成。

Artifact Registry 会创建您的代码库。运行以下命令以查看代码库的说明:

gcloud artifacts repositories describe REPOSITORY \
    --location=LOCATION

创建代码库后,请执行以下操作:

使用 Terraform 创建代码库

使用 google_artifact_registry_repository 资源创建代码库。 需要 terraform-provider-google 版本 5.0.0 或更高版本。

如果您刚开始将 Terraform 用于 Google Cloud,请参阅 HashiCorp 网站上的使用入门 - Google Cloud 页面。

以下示例定义了 Terraform 资源名称为 my-repo 的提供方和代码库。

公寓

provider "google" {
    project = "PROJECT-ID"
}

resource "google_artifact_registry_repository" "my-repo" {
  location = "LOCATION"
  repository_id = "REPOSITORY"
  description = "DESCRIPTION"
  format = "apt"
  kms_key_name = "KEY"
}

地点

  • PROJECT-ID 是 Google Cloud 项目 ID。
  • LOCATION 是代码库位置。
  • REPOSITORY 是代码库名称。
  • DESCRIPTION 是代码库的可选说明。请勿包含敏感数据,因为代码库说明未加密。
  • 如果您使用客户管理的加密密钥 (CMEK) 进行加密,则 KEY 是 Cloud Key Management Service 密钥的名称。省略此参数可使用默认设置,即 Google 管理的加密密钥。

Docker

provider "google" {
    project = "PROJECT-ID"
}

resource "google_artifact_registry_repository" "my-repo" {
  location = "LOCATION"
  repository_id = "REPOSITORY"
  description = "DESCRIPTION"
  format = "docker"
  kms_key_name = "KEY"
}

地点

  • PROJECT-ID 是 Google Cloud 项目 ID。
  • LOCATION 是代码库位置。
  • REPOSITORY 是代码库名称。
  • DESCRIPTION 是代码库的可选说明。请勿包含敏感数据,因为代码库说明未加密。
  • 如果您使用客户管理的加密密钥 (CMEK) 进行加密,则 KEY 是 Cloud Key Management Service 密钥的名称。省略此参数可使用默认设置,即 Google 管理的加密密钥。

KubeFlow 流水线

provider "google" {
    project = "PROJECT-ID"
}

resource "google_artifact_registry_repository" "my-repo" {
  location = "LOCATION"
  repository_id = "REPOSITORY"
  description = "DESCRIPTION"
  format = "kfp"
  kms_key_name = "KEY"
}

地点

  • PROJECT-ID 是 Google Cloud 项目 ID。
  • LOCATION 是代码库位置。
  • REPOSITORY 是代码库名称。
  • DESCRIPTION 是代码库的可选说明。请勿包含敏感数据,因为代码库说明未加密。
  • 如果您使用客户管理的加密密钥 (CMEK) 进行加密,则 KEY 是 Cloud Key Management Service 密钥的名称。省略此参数可使用默认设置,即 Google 管理的加密密钥。

Maven

如果您未指定版本政策,Artifact Registry 会创建一个 Maven 制品库,该制品库默认存储软件包的快照和发布版本

provider "google" {
    project = "PROJECT-ID"
}

resource "google_artifact_registry_repository" "my-repo" {
  location = "LOCATION"
  repository_id = "REPOSITORY"
  description = "DESCRIPTION"
  format = "maven"
  kms_key_name = "KEY"
}

地点

  • PROJECT-ID 是 Google Cloud 项目 ID。
  • LOCATION 是代码库位置。
  • REPOSITORY 是代码库名称。
  • DESCRIPTION 是代码库的可选说明。请勿包含敏感数据,因为代码库说明未加密。
  • 如果您使用客户管理的加密密钥 (CMEK) 进行加密,则 KEY 是 Cloud Key Management Service 密钥的名称。省略此参数可使用默认设置,即 Google 管理的加密密钥。

如需在不同的代码库中存储快照和发布版本,请使用 maven_config 块指定代码库的版本政策。此块支持以下设置:

  • version_policy 会将版本政策设置为以下值之一:
    • VERSION_POLICY_UNSPECIFIED:存储快照和发布软件包。这是默认设置。
    • 发布:仅存储发布版软件包。
    • 快照:仅存储快照软件包。
  • allow_snapshot_overwrites 用于配置具有 SNAPSHOT 版本政策的代码库,以接受覆盖代码库中现有版本的非唯一快照。

以下示例定义了具有发布版本政策的 Maven 制品库。

provider "google" {
project = "my-project"
}

resource "google_artifact_registry_repository" "my-repo" {
provider = google-beta

location = "us-central1"
repository_id = "my-repo"
description = "Maven repository"
format = "MAVEN"
maven_config {
  version_policy = "RELEASE"
}
}

npm

provider "google" {
    project = "PROJECT-ID"
}

resource "google_artifact_registry_repository" "my-repo" {
  location = "LOCATION"
  repository_id = "REPOSITORY"
  description = "DESCRIPTION"
  format = "npm"
  kms_key_name = "KEY"
}

地点

  • PROJECT-ID 是 Google Cloud 项目 ID。
  • LOCATION 是代码库位置。
  • REPOSITORY 是代码库名称。
  • DESCRIPTION 是代码库的可选说明。请勿包含敏感数据,因为代码库说明未加密。
  • 如果您使用客户管理的加密密钥 (CMEK) 进行加密,则 KEY 是 Cloud Key Management Service 密钥的名称。省略此参数可使用默认设置,即 Google 管理的加密密钥。

Python

provider "google" {
    project = "PROJECT-ID"
}

resource "google_artifact_registry_repository" "my-repo" {
  location = "LOCATION"
  repository_id = "REPOSITORY"
  description = "DESCRIPTION"
  format = "python"
  kms_key_name = "KEY"
}

地点

  • PROJECT-ID 是 Google Cloud 项目 ID。
  • LOCATION 是代码库位置。
  • REPOSITORY 是代码库名称。
  • DESCRIPTION 是代码库的可选说明。请勿包含敏感数据,因为代码库说明未加密。
  • 如果您使用客户管理的加密密钥 (CMEK) 进行加密,则 KEY 是 Cloud Key Management Service 密钥的名称。省略此参数可使用默认设置,即 Google 管理的加密密钥。

Artifact Registry 会创建您的代码库。运行以下命令以查看代码库的说明:

gcloud artifacts repositories describe REPOSITORY \
  --location=LOCATION

甜蜜

provider "google" {
    project = "PROJECT-ID"
}

resource "google_artifact_registry_repository" "my-repo" {
  location = "LOCATION"
  repository_id = "REPOSITORY"
  description = "DESCRIPTION"
  format = "yum"
  kms_key_name = "KEY"
}

地点

  • PROJECT-ID 是 Google Cloud 项目 ID。
  • LOCATION 是代码库位置。
  • REPOSITORY 是代码库名称。
  • DESCRIPTION 是代码库的可选说明。请勿包含敏感数据,因为代码库说明未加密。
  • 如果您使用客户管理的加密密钥 (CMEK) 进行加密,则 KEY 是 Cloud Key Management Service 密钥的名称。省略此参数可使用默认设置,即 Google 管理的加密密钥。

Go

provider "google" {
    project = "PROJECT-ID"
}

resource "google_artifact_registry_repository" "my-repo" {
  location = "LOCATION"
  repository_id = "REPOSITORY"
  description = "DESCRIPTION"
  format = "go"
  kms_key_name = "KEY"
}

地点

  • PROJECT-ID 是 Google Cloud 项目 ID。
  • LOCATION 是代码库位置。
  • REPOSITORY 是代码库名称。
  • DESCRIPTION 是代码库的可选说明。请勿包含敏感数据,因为代码库说明未加密。
  • 如果您使用客户管理的加密密钥 (CMEK) 进行加密,则 KEY 是 Cloud Key Management Service 密钥的名称。省略此参数可使用默认设置,即 Google 管理的加密密钥。

创建代码库后,请执行以下操作:

修改代码库说明

您可以通过 Google Cloud 控制台或 gcloud CLI 更改代码库说明。

控制台

  1. 打开 Google Cloud 控制台中的制品库页面。

    打开“代码库”页面

  2. 在代码库列表中,选择代码库,然后点击修改代码库

  3. 修改代码库说明,然后点击保存

gcloud

如需更新代码库说明,请运行以下命令:

gcloud artifacts repositories update REPOSITORY \
    --project=PROJECT] \
    --location=LOCATION \
    --description="DESCRIPTION"

替换以下值:

  • REPOSITORY 是代码库的名称。如果您配置了默认代码库,则可以省略此标志以使用默认值。
  • PROJECT 是 Google Cloud 项目 ID。如果省略此标志,则系统会使用当前项目或默认项目。
  • LOCATION 是单区域或多区域位置。使用此标志可查看特定位置的代码库。如果您配置了默认位置,可以省略此标志,以便使用默认位置。
  • DESCRIPTION 是代码库的说明。

后续步骤