En esta página, se describe el control de acceso con Identity and Access Management (IAM) en Artifact Registry.
Los permisos predeterminados para Artifact Registry minimizan el esfuerzo de configuración cuando con la implementación de una canalización de CI/CD. También puedes integrar Artifact Registry con herramientas de CI/CD de terceros y configurar los permisos y la autenticación necesarias para acceder a los repositorios.
Si usas Artifact Analysis para trabajar con metadatos de contenedores, como vulnerabilidades encontradas en las imágenes, consulta la Documentación de Artifact Analysis para obtener información sobre cómo otorgar acceso para ver o administrar metadatos.
Antes de comenzar
- Habilitar Artifact Registry incluida la habilitación de la API y la instalación de Google Cloud CLI.
- Si quieres aplicar permisos específicos del repositorio, crear un repositorio de Artifact Registry para tus paquetes.
Descripción general
Los permisos de IAM y los roles determinan tu capacidad para crear, ver, editar o borrar datos en un repositorio de Artifact Registry.
Un rol es un conjunto de permisos. No puedes otorgar permisos principales directamente. En su lugar, les otorgas una función. Cuando otorgas un rol a una principal, le otorgas todos los permisos que contiene ese rol. Puedes otorgar varios roles en la misma principal.
Permisos predeterminados de Google Cloud
De forma predeterminada, los siguientes permisos se aplican a los servicios de CI/CD de Google Cloud en el mismo proyecto que Artifact Registry:
- Los permisos de Cloud Build incluyen los permisos para subir y descargar artefactos.
- Compute Engine, las versiones compatibles de Google Kubernetes Engine y Cloud Run usan la cuenta de servicio predeterminada de Compute Engine, que tiene acceso de solo lectura al almacenamiento.
Si todos tus servicios están en el mismo proyecto de Google Cloud y la configuración los permisos satisfacen tus necesidades, no necesitas configurarlos.
Debes configurar los permisos de Artifact Registry para estos servicios si sucede lo siguiente:
- Deseas usar estos servicios para acceder a Artifact Registry en otro proyecto. En el proyecto con Artifact Registry, otorga la grupo de identidades para cargas de trabajo o cuenta de servicio para cada servicio rol requerido. Si te conectas a Cloud Run, otorga el permiso Agente de servicio de Cloud Run sea necesario en el área de la seguridad en la nube.
- estás usando una versión de GKE que no tiene asistencia para extraer imágenes de Artifact Registry. Consulta la En la sección de GKE, encontrarás las instrucciones de configuración.
- Deseas que la cuenta de servicio predeterminada tenga acceso de lectura y escritura a los repositorios. Consulta la siguiente información para obtener más detalles:
- usas una cuenta de servicio proporcionada por el usuario para tus entornos de ejecución en lugar de la cuenta de servicio predeterminada. En el proyecto con Artifact Registry, otorga a tu cuenta de servicio la función requerida.
Integración con terceros
Para los clientes de terceros, debes configurar los permisos y la autenticación.
Por lo general, las aplicaciones que se ejecutan fuera de Google Cloud usan claves de cuenta de servicio para acceder a los recursos de Google Cloud. Sin embargo, las claves de cuentas de servicio credenciales potentes y pueden presentar un riesgo de seguridad si no se administran correctamente.
La federación de identidades para cargas de trabajo te permite usar Identity and Access Management para otorgar roles de IAM a identidades externas incluida la capacidad de suplantar cuentas de servicio. Este enfoque elimina la carga de mantenimiento y seguridad asociada claves de cuenta.
Usa la federación de identidades para cargas de trabajo:
- Crea un grupo de federación de identidades para cargas de trabajo.
- Crea un proveedor de federación de identidades para cargas de trabajo.
- Otorga el rol adecuado de Artifact Registry a la carga de trabajo. para permitir el acceso al repositorio.
Configura tu cliente de terceros para que se autentique con Artifact Registry.
Usa una cuenta de servicio:
- Crea una cuenta de servicio que actúe en nombre de tu aplicación o elige una cuenta de servicio existente que se use para la automatización de CI/CD.
- Otorga la función adecuada de Artifact Registry a la cuenta de servicio para proporcionar acceso al repositorio.
Configura tu cliente de terceros para que se autentique con Artifact Registry.
GitLab en Google Cloud
La integración de GitLab en Google Cloud usa Federación de identidades para cargas de trabajo para la autorización y autenticación de Cargas de trabajo de GitLab en Google Cloud sin la necesidad de cuentas de servicio o claves de cuenta de servicio. Para obtener más información sobre cómo la federación de identidades para cargas de trabajo, se usa en esta asociación, consulta Descripción general de la autenticación.
Para configurar la federación de identidades para cargas de trabajo y los requisitos Roles de IAM para GitLab en Google Cloud, consulta el instructivo de GitLab Políticas de IAM y de federación de identidades para cargas de trabajo de Google Cloud.
Para conectar tu repositorio de Artifact Registry, sigue el instructivo de GitLab Google Artifact Registry
Funciones y permisos
Cada método de la API de Artifact Registry requiere que la principal (usuario, grupo o cuenta de servicio) que realiza la solicitud tiene los permisos necesarios para usar el recurso. Los permisos se otorgan a las principales mediante la configuración de políticas que otorgarle a la principal un rol predefinido en el recurso.
Puedes otorgar roles en el proyecto de Google Cloud o en Artifact Registry en un repositorio de confianza.
Roles predefinidos de Artifact Registry
IAM proporciona funciones predefinidas que otorgan acceso a recursos específicos de Google Cloud y evitan el acceso no autorizado a otros recursos.
Usa los siguientes roles predefinidos para estándar, virtual y remoto
Repositorios en el dominio pkg.dev
:
Rol | Descripción |
---|---|
Lector de Artifact Registry ( roles/artifactregistry.reader ) |
Visualiza y obtén artefactos, visualiza metadatos del repositorio. |
Escritor de Artifact Registry ( roles/artifactregistry.writer ) |
Leer y escribir artefactos |
Administrador del repositorio de Artifact Registry ( roles/artifactregistry.repoAdmin ) |
Leer, escribir y borrar artefactos |
Administrador de Artifact Registry ( roles/artifactregistry.admin ) |
Crear y administrar repositorios y artefactos |
Los siguientes roles predefinidos adicionales incluyen permisos para crear
Repositorios de gcr.io para alojar imágenes del dominio gcr.io
El
roles no incluyen permisos para crear otros formatos de repositorio en
Artifact Registry en el dominio pkg.dev
Estos roles admiten la transferencia
compatibilidad con Container Registry, ya que este usa el primer
push de una imagen de contenedor para crear cada registro multirregional.
Rol | Descripción |
---|---|
Escritor de creación automática al momento del envío de Artifact Registry
(roles/artifactregistry.createOnPushWriter ) |
Leer y escribir artefactos Crear repositorios de gcr.io |
Administrador del repositorio de Artifact Registry para envíos con creaciones
(roles/artifactregistry.createOnPushRepoAdmin ) |
Leer, escribir y borrar artefactos Crear repositorios de gcr.io |
Para ver una lista completa de los permisos individuales de cada rol, consulta
Roles de Artifact Registry
También puedes usar
gcloud iam roles describe
para ver una lista de los permisos de cada rol.
Funciones de IAM básicas
Los roles básicos son roles muy permisivos que existían antes de la introducción de IAM. Puedes usar roles básicos para otorgarles a las principales acceso a recursos de Google Cloud.
Usar roles predefinidos para repositorios acceder siempre que sea posible, de modo que los usuarios y las cuentas de servicio solo tengan los permisos necesarios.
Para obtener más información sobre los roles básicos, consulta Referencia de roles básicos y predefinidos de IAM.
Otorgando permisos
Otorga permisos a nivel de proyecto si los mismos permisos se aplican a todos los repositorios del proyecto. Si algunas cuentas requieren diferentes niveles de acceso, otorga funciones a nivel de repositorio.
Si otorgas permisos en un repositorio virtual, esos los permisos se aplican a todos los repositorios ascendentes disponibles a través de la sin importar los permisos individuales del repositorio.
Si otorgas roles con el comando gcloud
, puedes especificar un solo
la vinculación de roles para una principal o usa un archivo de política a fin de definir varias vinculaciones.
Otorga permisos en todo el proyecto
Otorga una función a nivel de proyecto si los mismos permisos se aplican a todos los repositorios del proyecto.
Para agregar un usuario o una cuenta de servicio a un proyecto y otorgarles un Rol de Artifact Registry:
Console
Abre la página de IAM en la consola de Google Cloud.
Haz clic en Seleccionar un proyecto, elige el proyecto en el que se ejecuta Artifact Registry y haz clic en Abrir.
Haga clic en Add.
Ingresa una dirección de correo electrónico. Puedes agregar personas individuales, cuentas de servicio o Grupos de Google como principales.
Selecciona un rol para la principal. De acuerdo con la política de principio de privilegio mínimo, considera otorgar el menor número de el privilegio necesario para acceder a los recursos necesarios de Artifact Registry. Para obtener información sobre Los roles y permisos predefinidos de Artifact Registry, consulta Roles predefinidos de Artifact Registry
Haz clic en Guardar.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Para otorgar un rol a una sola principal, ejecuta el siguiente comando:
gcloud projects add-iam-policy-binding PROJECT \ --member=PRINCIPAL \ --role=ROLE
donde
- PROJECT es el ID del proyecto en el que Artifact Registry se esté ejecutando.
PRINCIPAL es el principal al que se agregará la vinculación. Usa el formulario
user|group|serviceAccount:email
odomain:domain
.Ejemplos:
user:test-user@gmail.com
,group:admins@example.com
,serviceAccount:test123@example.domain.com
odomain:example.domain.com
.ROLE es la función que deseas otorgar.
Para obtener más información, consulta la documentación de add-iam-policy-binding.
Para otorgar funciones mediante un archivo de políticas, ejecuta el siguiente comando:
gcloud projects set-iam-policy PROJECT /PATH/TO/policy.yaml
Donde
- PROJECT es el ID del proyecto o el identificador completamente calificado para el proyecto en el que se ejecuta Artifact Registry.
- /PATH/TO/policy.yaml es la ruta de acceso y el nombre de archivo del archivo de políticas.
Para obtener la política configurada actual, ejecuta el siguiente comando:
gcloud projects get-iam-policy PROJECT
En el ejemplo anterior, PROJECT es el ID del proyecto o el identificador completamente calificado para el proyecto.
Para obtener más información, consulta la documentación de set-iam-policy.
Otorga permisos específicos del repositorio
Otorga permisos a nivel de repositorio cuando desees que los usuarios o las cuentas de servicio tengan diferentes niveles de acceso para cada repositorio del proyecto.
Console
Para otorgar acceso a un repositorio específico, haz lo siguiente:
Abre la página Repositorios en la consola de Google Cloud.
Selecciona el repositorio adecuado.
Si no se muestra el panel de información, haz clic en Mostrar panel de información en la barra de menú.
En la pestaña Permisos, haz clic en Agregar principal.
Ingresa una dirección de correo electrónico. Puedes agregar personas, cuentas de servicio o cuentas Se agrupan como principales.
Selecciona un rol para la principal. De acuerdo con la política de principio de privilegio mínimo, considera otorgar el menor número de el privilegio necesario para acceder a los recursos necesarios de Artifact Registry. Para sobre los permisos y roles predefinidos de Artifact Registry consulta Roles predefinidos de Artifact Registry.
Haz clic en Guardar.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Puedes configurar un conjunto de IAM de vinculaciones de políticas individuales o usar un archivo de políticas.
Para otorgar un rol a una sola principal, ejecuta el siguiente comando:
gcloud artifacts repositories add-iam-policy-binding REPOSITORY \ --location=LOCATION \ --member=PRINCIPAL \ --role=ROLE
donde
- REPOSITORY es el ID del repositorio.
PRINCIPAL es el principal al que se agregará la vinculación. Usa el formulario
user|group|serviceAccount:email
odomain:domain
.Ejemplos:
user:test-user@gmail.com
,group:admins@example.com
,serviceAccount:test123@example.domain.com
odomain:example.domain.com
.ROLE es la función que deseas otorgar.
LOCATION es la ubicación regional o multirregional del repositorio.
Por ejemplo, si deseas agregar una vinculación de una política de IAM para la función
roles/artifactregistry.writer
para el usuariowrite@gmail.com
con el repositoriomy-repo
en la ubicación--us-central1
, ejecuta lo siguiente:gcloud artifacts repositories add-iam-policy-binding my-repo \ --location=us-central1 --member=user:write@gmail.com --role=roles/artifactregistry.writer
Para otorgar funciones mediante un archivo de políticas, ejecuta el siguiente comando:
gcloud artifacts repositories set-iam-policy REPOSITORY /PATH/TO/policy.yaml --location=LOCATION
Donde
- REPOSITORY es el ID del repositorio.
- /PATH/TO/policy.yaml es la ruta de acceso y el nombre de archivo del archivo de políticas.
- LOCATION es la ubicación regional o multirregional del repositorio.
Por ejemplo, a fin de establecer la política de IAM del repositorio
my-repo
en la ubicación--us-central1
con la política definida enpolicy.yaml
, ejecuta lo siguiente:gcloud artifacts repositories set-iam-policy my-repo policy.yaml --location=us-central1
Terraform
Usa el recurso google_artifact_registry_repository_iam para
configurar una política de IAM. En el siguiente ejemplo, se define un servicio
con el nombre de recurso repo-account
y le otorga acceso de lectura a un
repositorio con el nombre de recurso my-repo
.
Si es la primera vez que usas Terraform para Google Cloud, consulta el Get Started - Google Cloud en la Sitio web de HashiCorp.
provider "google" {
project = "PROJECT-ID"
}
resource "google_artifact_registry_repository" "my-repo" {
provider = google-beta
location = "LOCATION"
repository_id = "REPOSITORY"
description = "DESCRIPTION"
format = "FORMAT"
}
resource "google_service_account" "repo-account" {
provider = google-beta
account_id = "ACCOUNT-ID"
display_name = "Repository Service Account"
}
resource "google_artifact_registry_repository_iam_member" "repo-iam" {
provider = google-beta
location = google_artifact_registry_repository.my-repo.location
repository = google_artifact_registry_repository.my-repo.name
role = "roles/artifactregistry.reader"
member = "serviceAccount:${google_service_account.repo-account.email}"
}
ACCOUNT-ID es el ID de la cuenta de servicio. Esta es la parte del campo de correo electrónico de la cuenta de servicio antes del símbolo @
.
Para ver más ejemplos, consulta la documentación del google_artifact_registry_repository_iam recurso.
Configura el acceso público a un repositorio
Si tienes artefactos que deseas que estén disponibles para cualquier persona en Internet sin necesidad de autenticación, almacénalos en un repositorio que hagas público.
Si quieres configurar un repositorio con acceso público de solo lectura, otorga al
Rol de lector de Artifact Registry para la principal allUsers
. También recomendamos
limitar las cuotas de solicitudes del usuario para que
usuario no puede agotar la cuota general de tu proyecto.
Console
Abre la página Repositorios en la consola de Google Cloud.
Selecciona el repositorio adecuado.
Si no se muestra el panel de información, haz clic en Mostrar panel de información en la barra de menú.
En la pestaña Permisos, haz clic en Agregar principal.
En el campo Principales nuevas, ingresa
allUsers
.Selecciona el rol Lector de Artifact Registry.
Establece un límite por usuario en las solicitudes a la API de Artifact Registry para evitar el uso inadecuado por parte de usuarios no autenticados. Consulta Limita el uso para obtener instrucciones.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Ejecuta el siguiente comando:
gcloud artifacts repositories add-iam-policy-binding REPOSITORY \ --location=LOCATION --member=allUsers --role=ROLE
donde
REPOSITORY es el ID del repositorio.
ROLE es la función que deseas otorgar.
LOCATION es la ubicación regional o multirregional del repositorio.
Por ejemplo, para configura el repositorio
my-repo
en la ubicación--us-central1
como un repositorio público, ejecuta lo siguiente:gcloud artifacts repositories add-iam-policy-binding my-repo \ --location=us-central1 --member=allUsers --role=roles/artifactregistry.reader
Establece un límite por usuario en las solicitudes a la API de Artifact Registry para evitar el uso inadecuado por parte de usuarios no autenticados. Consulta Limita el uso para obtener instrucciones.
Revoca permisos
Para revocar el acceso a un repositorio, quita la principal de la lista de principales.
Para quitar el acceso público de un repositorio, quita la principal allUsers
.
Console
Para revocar permisos, haz lo siguiente:
Abre la página Repositorios en la consola de Google Cloud.
Selecciona el repositorio adecuado.
Si no se muestra el panel de información, haz clic en Mostrar panel de información en la barra de menú.
En la pestaña Permisos, expande la principal correspondiente. Si si conviertes un repositorio público en privado, expande la principal
allUsers
.Haz clic en Quitar principal para revocar el acceso.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Para revocar una función a nivel de proyecto, ejecuta el siguiente comando:
gcloud projects remove-iam-policy-binding PROJECT \ --member=PRINCIPAL \ --role=ROLE
- PROJECT es el ID del proyecto.
PRINCIPAL es la principal para la que se quitará la vinculación. Usa el formulario
user|group|serviceAccount:email
odomain:domain
.Ejemplos:
user:test-user@gmail.com
,group:admins@example.com
,serviceAccount:test123@example.domain.com
odomain:example.domain.com
.ROLE es la función que deseas revocar.
Para revocar una función de un repositorio, ejecuta el siguiente comando:
gcloud artifacts repositories remove-iam-policy-binding REPOSITORY --location=LOCATION \ --member=PRINCIPAL \ --role=ROLE
donde
- REPOSITORY es el ID del repositorio.
PRINCIPAL es la principal para la que se quitará la vinculación. Usa el formulario
user|group|serviceAccount:email
odomain:domain
.Ejemplos:
user:test-user@gmail.com
,group:admins@example.com
,serviceAccount:test123@example.domain.com
odomain:example.domain.com
.Para revocar el acceso público al repositorio, especifica la principal
allUsers
.ROLE es la función que deseas revocar.
Por ejemplo, a fin de quitar una vinculación de una política para la función
roles/artifactregistry.writer
del usuariowrite@gmail.com
con el repositoriomy-repo
en la ubicación--us-central1
, ejecuta lo siguiente:gcloud artifacts repositories remove-iam-policy-binding my-repo \ --location=us-central1 \ --member=user:write@gmail.com \ --role=roles/artifactregistry.writer
Para revocar el acceso público a
my-repo
en la ubicación--us-central1
, ejecuta lo siguiente:gcloud artifacts repositories remove-iam-policy-binding my-repo \ --location=us-central1 \ --member=allUsers \ --role=roles/artifactregistry.reader
Otorga acceso condicional con etiquetas
Los administradores de proyectos pueden crear etiquetas para los recursos de Google Cloud y administrarlas en Resource Manager. Cuando adjuntas una etiqueta a un En el repositorio de Artifact Registry, los administradores pueden usar la etiqueta Condiciones de IAM para otorgar acceso condicional al repositorio.
No puedes adjuntar etiquetas a artefactos individuales.
Para obtener más información, consulta la siguiente documentación:
- Administradores que configuran las etiquetas y el control de acceso
- Desarrolladores que adjuntan etiquetas a los repositorios
Integra los servicios de Google Cloud
Para la mayoría de las cuentas de servicio de Google Cloud, configurar el acceso a un registro solo requiere otorgar los permisos de IAM adecuados.
Permisos predeterminados para los servicios de Google Cloud
Los servicios de Google Cloud, como Cloud Build o Google Kubernetes Engine, usan un cuenta de servicio predeterminada o agente de servicio con el que interactuar recursos dentro del mismo proyecto.
Debes configurar o modificar los permisos tú mismo si:
- El servicio de Google Cloud está en un proyecto diferente al de Artifact Registry.
- Los permisos predeterminados no satisfacen tus necesidades. Por ejemplo, la configuración predeterminada Compute Engine tiene acceso de solo lectura al almacenamiento en el mismo en un proyecto final. Si quieres enviar una imagen de una VM a Artifact Registry, puedes puede modificar los permisos de la cuenta de servicio de la VM o usar una cuenta diferente con los permisos necesarios.
- usas una cuenta de servicio proporcionada por el usuario con la que interactuar Artifact Registry en lugar de la cuenta de servicio predeterminada.
Las siguientes cuentas de servicio suelen acceder a Artifact Registry. El dirección de correo electrónico de la cuenta de servicio incluye Google Cloud ID o número del proyecto del proyecto en el que se ejecuta el servicio.
Servicio | Cuenta de servicio | Dirección de correo electrónico | Permisos |
---|---|---|---|
Entorno flexible de App Engine | App Engine cuenta de servicio | PROJECT-ID@appspot.gserviceaccount.com | Editor, puede leer y escribir en los repositorios |
Compute Engine | Cuenta de servicio predeterminada de Compute Engine | PROJECT-NUMBER-compute@developer.gserviceaccount.com | Rol de editor, limitado al acceso de solo lectura a los repositorios |
Cloud Build | Servicio de Cloud Build cuenta | PROJECT-NUMBER@cloudbuild.gserviceaccount.com |
Permisos predeterminados incluyen acceso de lectura y escritura a los repositorios y la capacidad de crear Repositorios de gcr.io. |
Cloud Run |
Agente de servicio de Cloud Run El agente de servicio de run.googleapis.com . |
service-PROJECT-NUMBER@serverless-robot-prod.iam.gserviceaccount.com | Permisos de lector, limitados al acceso de solo lectura a los repositorios |
GKE |
Cuenta de servicio predeterminada de Compute Engine La cuenta de servicio predeterminada para los nodos. |
PROJECT-NUMBER-compute@developer.gserviceaccount.com | Rol de editor, limitado al acceso de solo lectura a los repositorios |
Otorga acceso a las instancias de Compute Engine
Las instancias de VM que acceden a los repositorios deben tener configurados el permiso de acceso almacenamiento y los permisos de Artifact Registry.
Si bien el nivel de acceso de una cuenta de servicio está determinado por Roles de IAM otorgados a la cuenta de servicio, permisos de acceso en una instancia de VM determinan los alcances de OAuth predeterminados para las solicitudes realizadas a través del para gcloud CLI y las bibliotecas cliente en la instancia. Como resultado, los permisos de acceso limitar potencialmente aún más el acceso a los métodos de la API cuando se autentique con Credenciales predeterminadas de la aplicación.
Compute Engine usa los siguientes valores predeterminados:
- La cuenta de servicio predeterminada de Compute Engine es la identidad de la VM individuales. La dirección de correo electrónico de la cuenta de servicio tiene el sufijo @developer.gserviceaccount.com.
- La cuenta de servicio predeterminada tiene el rol IAM editor, si aún no inhabilitaste este comportamiento.
- Las instancias que crees con la cuenta de servicio predeterminada tendrán la
Los permisos de acceso predeterminados de Compute Engine, incluidos
acceso de solo lectura al almacenamiento. El rol Editor suele otorgar permiso
el permiso de acceso al almacenamiento
read-only
limita el servicio de la instancia para descargar artefactos solo de cualquier repositorio en el mismo proyecto.
Debes configurar el permiso de acceso de la cuenta de servicio si sucede lo siguiente:
- La cuenta de servicio de VM debe acceder a un repositorio en un proyecto diferente.
- La cuenta de servicio de VM debe realizar acciones que no sean la lectura de artefactos de repositorios. Por lo general, esto aplica herramientas de terceros en una VM que necesita enviar imágenes o ejecutar comandos de
gcloud
de Artifact Registry.
Para configurar los permisos y establecer el permiso de acceso, haz lo siguiente:
En el proyecto que tiene la instancia de VM, obtén el nombre de la cuenta de servicio predeterminada de Compute Engine. La dirección de correo electrónico de la cuenta de servicio tiene el sufijo @developer.gserviceaccount.com.
En el proyecto que tiene el repositorio, otorga permisos para que la cuenta de servicio pueda acceder al repositorio.
Configura el permiso de acceso con la opción --scopes.
Detén la instancia de VM. Consulta Detén una instancia.
Establece el permiso de acceso mediante el siguiente comando:
gcloud compute instances set-service-account INSTANCE --scopes=SCOPE
Reemplaza SCOPE por el valor adecuado.
En Docker, se admiten las siguientes opciones:
storage-ro
: Otorga permiso de lectura solo para extraer imágenes.storage-rw
: Otorga permiso de lectura y escritura para enviar o extraer imágenes.cloud-platform
: Permite ver y administrar datos, incluidos los metadatos, en el servicio de Google Cloud.
Para otros formatos, debes usar el permiso
cloud-platform
.
Reinicia la instancia de VM. Consulta Inicia una instancia detenida.
Otorga acceso a los clústeres de Google Kubernetes Engine
Los clústeres y grupos de nodos de GKE pueden extraer contenedores sin ninguna configuración adicional si se cumplen todos los siguientes requisitos:
- GKE se encuentra en el mismo proyecto que Artifact Registry.
- Los nodos usan la cuenta de servicio predeterminada, que es la cuenta de servicio predeterminada de Compute Engine.
- Los nodos se crearon con acceso de lectura al almacenamiento de la siguiente manera:
- Usar los permisos de acceso predeterminados de Compute Engine
- Otorgar el permiso de acceso
cloud-platform
o algún otro permiso que incluya acceso de lectura al almacenamiento.
- Debes ejecutar una versión compatible de GKE.
Si tu entorno de GKE no cumple con estos requisitos, las instrucciones para otorgar acceso dependerán de si estás usando el cuenta de servicio predeterminada de Compute Engine o una cuenta de servicio proporcionada por el usuario como la identidad de tus nodos.
- Cuenta de servicio predeterminada
Los siguientes requisitos de configuración se aplican a la cuenta de servicio predeterminada de Compute Engine:
Si GKE está en un proyecto diferente al Artifact Registry, otorga los permisos necesarios a la cuenta de servicio.
Para enviar imágenes, interactúa con los repositorios para formatos que no sean contenedores o ejecutar comandos de
gcloud
desde tu clúster, debes configurar permisos de acceso para la cuenta de servicio cuando crees clúster o grupo de nodos.Si no estás usando una versión compatible de GKE, configura imagePullSecrets.
- Cuenta de servicio proporcionada por el usuario
Si quieres usar una cuenta de servicio proporcionada por el usuario como la identidad de un clúster, debes hacer lo siguiente:
Otorga los permisos necesarios a la cuenta de servicio desde la Proyecto de Google Cloud en el que se ejecuta Artifact Registry.
De forma predeterminada, la creación de un clúster o grupo de nodos con un servicio proporcionado por el usuario La cuenta otorga el permiso de acceso de
cloud-platform
.Si usas la marca
--scopes
con el gcloud container clusters create o comando gcloud container node-pools create, debes incluir los permisos de acceso para usar con Artifact Registry.
Configura permisos de acceso
Los permisos de acceso son el método heredado de especificar autorización para VMs de Compute Engine. Para extraer imágenes de repositorios de Artifact Registry, Los nodos de GKE deben tener permiso de acceso de solo lectura al almacenamiento o otro permiso de acceso al almacenamiento que incluya acceso de lectura al almacenamiento.
Solo puedes configurar permisos de acceso cuando creas un clúster o un grupo de nodos. Tú no puede cambiar los permisos de acceso en los nodos existentes.
- Si usas la cuenta de servicio predeterminada de Compute Engine, GKE crea nodos con el Compute Engine permisos de acceso predeterminados, que incluye acceso de solo lectura a y almacenamiento de los datos.
- Si usas una cuenta de servicio proporcionada por el usuario, GKE crea
nodos con el permiso
cloud-platform
, el permiso requerido para la mayoría de servicios de Google Cloud.
Para especificar permisos de acceso cuando creas un clúster, ejecuta el siguiente comando:
gcloud container clusters create NAME --scopes=SCOPES
Para especificar permisos de acceso cuando creas un grupo de nodos, ejecuta el siguiente comando:
gcloud container node-pools create NAME --scopes=SCOPES
Reemplaza los siguientes valores:
- NAME es el nombre del clúster o grupo de nodos.
SCOPES es una lista separada por comas de permisos de acceso para otorgar.
Para acceder a los repositorios de Docker, usa uno de los siguientes alcances:
storage-ro
: Otorga permiso de solo lectura para extraer imágenes.storage-rw
: Otorga permiso de lectura y escritura para enviar o extraer imágenes.cloud-platform
: Permite ver y administrar datos, incluidos los metadatos, en el servicio de Google Cloud.Para acceder a otros repositorios, debes usar el permiso
cloud-platform
.
Para obtener una lista completa de los alcances, consulta la documentación de gcloud container clusters create o gcloud container node-pools create.
Para obtener más información sobre los permisos que puedes configurar cuando creas un clúster nuevo, consulta la documentación del comando gcloud container clusters create.
Configura un imagePullSecret
Para configurar un imagePullSecret
, haz lo siguiente:
En el proyecto con GKE, busca la instancia predeterminada de Compute Engine cuenta de servicio. La dirección de correo electrónico de la cuenta tiene el sufijo @developer.gserviceaccount.com.
Descarga la clave de la cuenta de servicio para la cuenta de servicio.
En el proyecto que tiene el repositorio, verifica que haber otorgado permisos al repositorio.
En el proyecto que tiene el clúster, crea un secreto
imagePullSecret
llamadoartifact-registry
con la clave de la cuenta de servicio.kubectl create secret docker-registry artifact-registry \ --docker-server=https://LOCATION-docker.pkg.dev \ --docker-email=SERVICE-ACCOUNT-EMAIL \ --docker-username=_json_key \ --docker-password="$(cat KEY-FILE)"
Donde
- LOCATION es la ubicación regional o multirregional del repositorio.
- SERVICE-ACCOUNT-EMAIL es la dirección de correo electrónico de la cuenta de servicio de Compute Engine.
- KEY-FILE es el nombre del archivo de claves de la cuenta de servicio. Por ejemplo,
key.json
.
Abre tu cuenta de servicio predeterminada:
kubectl edit serviceaccount default --namespace default
Cada espacio de nombres en tu clúster de Kubernetes tiene una cuenta de servicio predeterminada llamada
default
. Esta cuenta de servicio predeterminada se usa para extraer la imagen del contenedor.Agrega el secreto
imagePullSecret
recién creado a tu cuenta de servicio predeterminada:imagePullSecrets: - name: artifact-registry
Tu cuenta de servicio debería verse así:
apiVersion: v1 kind: ServiceAccount metadata: name: default namespace: default ... secrets: - name: default-token-zd84v # The secret you created: imagePullSecrets: - name: artifact-registry
Ahora, todos los Pods nuevos creados en el espacio de nombres default
actual tendrán definido el secreto imagePullSecret
.
Cuenta de servicio de Artifact Registry
El agente de servicio de Artifact Registry es una cuenta de servicio administrada por Google que actúa en nombre de Artifact Registry cuando interactúa con Google Cloud de Google Cloud. Para obtener más información sobre la cuenta y sus permisos, consulta Cuenta de servicio de Artifact Registry
¿Qué sigue?
Después de configurar los permisos, obtén más información sobre cómo trabajar con los artefactos.
- Imágenes de contenedor: Docker, Helm
- Paquetes de lenguajes: Java, Node.js, Python y Go
- Paquetes de SO: Debian, RPM