Crea un repositorio remoto de Docker Hub

Crea un repositorio remoto para que actúe como proxy de Docker Hub.

Antes de comenzar

  1. Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  3. Make sure that billing is enabled for your Google Cloud project.

  4. Enable the Artifact Registry, Secret Manager APIs.

    Enable the APIs

  5. Install the Google Cloud CLI.
  6. To initialize the gcloud CLI, run the following command:

    gcloud init
  7. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  8. Make sure that billing is enabled for your Google Cloud project.

  9. Enable the Artifact Registry, Secret Manager APIs.

    Enable the APIs

  10. Install the Google Cloud CLI.
  11. To initialize the gcloud CLI, run the following command:

    gcloud init
  12. Crea una cuenta de Docker Hub.

Roles obligatorios

Para obtener los permisos que necesitas para crear un repositorio remoto de Docker Hub, pídele a tu administrador que te otorgue los siguientes roles de IAM:

Para obtener más información sobre cómo otorgar roles, consulta Administra el acceso a proyectos, carpetas y organizaciones.

También puedes obtener los permisos necesarios mediante roles personalizados o cualquier otro rol predefinido.

Elige una shell

Para completar esta guía de inicio rápido, usa Cloud Shell o tu shell local.

Cloud Shell
Cloud Shell es un entorno de shell que se usa para administrar recursos alojados en Google Cloud. Viene preinstalado con Docker y la CLI de Google Cloud, la interfaz de línea de comandos principal para Google Cloud.
Shell local
Si prefieres usar tu shell local, debes instalar Docker y gcloud CLI en tu entorno.

Inicia Cloud Shell

Para iniciar Cloud Shell, sigue estos pasos:

  1. Ve a la consola de Google Cloud.

    Consola de Google Cloud

  2. Haz clic en el botón Activar Cloud Shell:  .

Se abrirá una sesión de Cloud Shell dentro de un marco en la parte inferior en la consola. Usa esta shell para ejecutar los comandos de gcloud.

Configura una shell local

Para instalar gcloud CLI y Docker, sigue estos pasos:

  1. Instala la CLI de gcloud. Para actualizar una instalación existente, ejecuta el comando gcloud components update.

  2. Instala Docker si aún no lo hiciste.

  3. Docker necesita acceso con privilegios para interactuar con los registros. En Linux o Windows, agrega el usuario que usas para ejecutar comandos de Docker al grupo de seguridad de Docker. Este paso no es necesario en macOS, ya que Docker Desktop se ejecuta en una máquina virtual como usuario raíz.

    Linux

    El grupo de seguridad de Docker se llama docker. Para agregar tu nombre de usuario, ejecuta el siguiente comando:

    sudo usermod -a -G docker ${USER}
    

    Windows

    El grupo de seguridad de Docker se llama docker-users. Para agregar un usuario desde el símbolo del sistema del administrador, ejecuta el siguiente comando:

    net localgroup docker-users DOMAIN\USERNAME /add
    

    Donde

    • DOMAIN es tu dominio de Windows.
    • USERNAME es tu nombre de usuario.
  4. Sal de tu cuenta y vuelve a acceder para que se apliquen los cambios de membresía de grupo. Si utilizas una máquina virtual, es posible que tengas que reiniciarla para que se apliquen los cambios de membresía.

  5. Para asegurarte de que Docker esté funcionando, ejecuta el siguiente comando de Docker, que muestra la hora y la fecha actuales:

    docker run --rm busybox date
    

    La marca --rm borra la instancia de contenedor cuando se sale.

Configura la autenticación de Docker Hub

Para evitar el uso de la cuota de Docker Hub no autenticada, te recomendamos que te autentiques en Docker Hub cuando uses repositorios remotos. Repositorios remotos te permiten agregar tu nombre de usuario de Docker Hub y un token de acceso personal guardado como un secreto para autenticar Docker Hub.

Crea un token de acceso personal de Docker Hub

  1. Accede a Docker Hub.
  2. Crea un token de acceso personal con permisos de solo lectura.
  3. Copia el token de acceso.

  4. Guarda el token de acceso en un archivo de texto en tu entorno local o en Cloud Shell.

Guarda tu token de acceso personal en un secreto

Console

  1. Ve a la página de Secret Manager en la consola de Google Cloud.

    Ir a la página Secret Manager

  2. En la página de Secret Manager, haz clic en Crear secreto.

  3. En la página Crear secreto, en Nombre, asigna el nombre my-secret a tu secreto.

  4. En el campo Valor del secreto, ingresa tu token de acceso personal de Docker Hub.

  5. Deja la sección Regiones sin modificar.

  6. Haz clic en el botón Crear secreto.

gcloud CLI

gcloud secrets create my-secret --data-file="/path/to/file.txt"

Donde /path/to/file.txt es la ubicación del archivo de texto con tu token de acceso personal.

Otorga a la cuenta de servicio de Artifact Registry acceso a tu secreto.

Console

  1. Ve a la página de Secret Manager en la consola de Google Cloud.

    Ir a la página Secret Manager

  2. En la página de Secret Manager, haz clic en la casilla de verificación junto a my-secret.

  3. Si aún no está abierto, haz clic en Mostrar panel de información para abrir el panel.

  4. En el panel de información, haz clic en Agregar principal.

  5. En el área de texto Principales nuevas, ingresa la dirección de correo electrónico de la cuenta de servicio de Artifact Registry. La dirección de correo electrónico de la cuenta de servicio de Artifact Registry tiene el siguiente formato:

    service-PROJECT-NUMBER@gcp-sa-artifactregistry.iam.gserviceaccount.com

    En el ejemplo anterior, PROJECT-NUMBER es el número del proyecto.

    Para encontrar el número de tu proyecto, haz lo siguiente:

    • Ve a la página Panel en la consola de Google Cloud.

      Ve a la página Panel

    • Haz clic en la lista desplegable Seleccionar desde en la parte superior de la página.

    • En la ventana Seleccionar una opción que aparece, elige tu proyecto.

      El ID y el número del proyecto se muestran en la tarjeta de Información del proyecto del panel del proyecto.

  6. En el menú desplegable Selecciona una función, selecciona Secret Manager y, luego, Administrador y descriptor de acceso a Secretos.

gcloud CLI

gcloud secrets add-iam-policy-binding my-secret \
    --member="serviceAccount:service-PROJECT-NUMBER@gcp-sa-artifactregistry.iam.gserviceaccount.com" \
    --role="roles/secretmanager.secretAccessor"

En el ejemplo anterior, PROJECT-NUMBER es el número de tu proyecto.

Para encontrar el número de tu proyecto, haz lo siguiente:

  • Ve a la página Panel. en la consola de Google Cloud.

    Ve a la página Panel

  • Haz clic en la lista desplegable Seleccionar desde en la parte superior de la página.

  • En la ventana Seleccionar una opción que aparece, elige tu proyecto.

    El ID y el número del proyecto se muestran en la tarjeta Información del proyecto del panel del proyecto.

Crea un repositorio remoto

Ejecuta el siguiente comando para crear un repositorio remoto de Artifact Registry llamado quickstart-docker-hub-remote en la ubicación us-central1 con tus credenciales de Docker Hub:

gcloud artifacts repositories create quickstart-docker-hub-remote \
    --project=PROJECT_ID \
    --repository-format=DOCKER  \
    --location=us-central1 \
    --description="Remote Docker repository" \
    --mode=remote-repository \
    --remote-repo-config-desc="Docker Hub" \
    --remote-docker-repo=DOCKER-HUB \
    --remote-username=USERNAME \
    --remote-password-secret-version=projects/PROJECT/secrets/my-secret/versions/1

Aquí:

  • quickstart-docker-hub-remote es el nombre del repositorio. Para la ubicación de cada repositorio en un proyecto, los nombres de los repositorios deben ser únicos.
  • PROJECT_ID es el ID del proyecto. Si se omite esta marca, se usa el proyecto actual o predeterminado.
  • us-central1 es la ubicación regional o multirregional del repositorio. Puedes omitir esta marca si estableces un valor predeterminado. Para ver una lista de las ubicaciones compatibles, ejecuta el comando gcloud artifacts locations list.
  • "Remote Docker repository" es la descripción opcional de tu repositorio. No incluyas datos sensibles, ya que las descripciones del repositorio están encriptados.
  • "Docker Hub" es la descripción opcional de la configuración del repositorio externo para este repositorio remoto.
  • DOCKER-HUB establece el repositorio remoto upstream en el upstream público de Docker Hub.
  • USERNAME es tu nombre de usuario de Docker Hub.
  • projects/PROJECT/secrets/my-secret/versions/1 es la versión secreta que creaste para almacenar tu token de acceso personal de Docker Hub.

Artifact Registry crea el repositorio y lo agrega a la lista de de Cloud Storage.

Configura la autenticación de Docker

Antes de poder enviar o extraer imágenes, debes configurar Docker para que use Google Cloud CLI de modo que puedas autenticar las solicitudes a Artifact Registry.

  1. Accede a gcloud CLI como el usuario que ejecutará los comandos de Docker.

    gcloud auth login
    
  2. Para configurar la autenticación en los repositorios de Docker en la región us-central1, ejecuta el siguiente comando:

    gcloud auth configure-docker us-central1-docker.pkg.dev
    

    El comando actualiza tu configuración de Docker. Ahora puedes conectarte con Artifact Registry en tu proyecto de Google Cloud para enviar y extraer imágenes.

Para obtener información sobre otros métodos de autenticación, consulta Métodos de autenticación.

Extrae una imagen a tu repositorio remoto

  1. Accede a gcloud CLI como el usuario que ejecutará los comandos de Docker.

    gcloud auth login
    
  2. Extrae una imagen de Docker Hub a tu máquina y a tu dispositivo remoto. repositorio con el siguiente comando:

    docker pull us-central1-docker.pkg.dev/PROJECT/quickstart-docker-hub-remote/busybox:latest
    

    Aquí:

    • us-central1 es la ubicación del repositorio remoto.
    • us-central1-docker.pkg.dev es el nombre de host para el repositorio de Docker. que creaste.
    • PROJECT es tu cuenta de Google Cloud ID del proyecto: Si el ID de tu proyecto contiene dos puntos (:), consulta Proyectos con alcance de dominio.
    • quickstart-docker-hub-remote es el ID del repositorio que creaste.
    • busybox es el nombre de la imagen que deseas extraer de Docker Hub a quickstart-docker-hub-remote.
    • latest es la versión de la imagen etiquetada que deseas extraer de Docker Hub.

    La imagen se extrae de tu máquina y se almacena en caché en el repositorio remoto. Si vuelves a extraer la misma imagen etiquetada, se extraerá del control remoto. en un repositorio de confianza. Se usan tus credenciales de Docker Hub.

  3. Haz una lista de los artefactos almacenados en tu repositorio remoto:

    gcloud artifacts packages list \
        --location=us-central1 \
        --repository=quickstart-docker-hub-remote
    

    El resultado se ve de la manera siguiente:

    Listing items under project my-project, location us-central1, repository quickstart-docker-hub-remote.
    
    PACKAGE: busybox
    CREATE_TIME: 2023-06-19T18:59:09
    UPDATE_TIME: 2023-06-19T18:59:10
    

Limpia

Sigue estos pasos para evitar que se apliquen cargos a tu cuenta de Google Cloud por los recursos que usaste en esta página.

Borra tu repositorio

Si quieres conservar tu proyecto y solo borrar el recurso del repositorio, sigue los pasos que se indican en esta sección. Si quieres borrar todo el proyecto, sigue los pasos que se indican en Borra tu proyecto

Antes de quitar el repositorio, asegúrate de que las imágenes que quieres conservar estén disponibles en otra ubicación.

Para borrar el repositorio, haz lo siguiente:

Console

  1. Abre la página Repositorios en la consola de Google Cloud.

    Abrir la página Repositorios

  2. En la lista de repositorios, selecciona el repositorio quickstart-docker-hub-remote.

  3. Haz clic en Borrar.

gcloud

Para borrar el repositorio quickstart-docker-hub-remote, ejecuta el siguiente comando:

gcloud artifacts repositories delete quickstart-docker-hub-remote \
    --location=us-central1

Borra tu proyecto

  1. In the Google Cloud console, go to the Manage resources page.

    Go to Manage resources

  2. In the project list, select the project that you want to delete, and then click Delete.
  3. In the dialog, type the project ID, and then click Shut down to delete the project.

¿Qué sigue?