Compila fuentes en contenedores

Cloud Run admite la implementación directa de código fuente. Sin embargo, también puedes compilar tu código fuente en una imagen de contenedor y, luego, implementar esta imagen de contenedor en Cloud Run. Puedes usar imágenes de contenedor para cualquier recurso de Cloud Run.

Estos son algunos casos de uso comunes para desacoplar las operaciones de compilación y de implementación:

  • Integración y entrega continuas: Los desarrolladores crean y envían código a un repositorio de código fuente. Un sistema de CI/CD compila automáticamente este código fuente en un contenedor, ejecuta pruebas y lo implementa automáticamente en un entorno de pruebas.
  • Infraestructura como código: Los recursos de Cloud Run que se administran con YAML o Terraform hacen referencia a una URL de imagen de contenedor. El código fuente escrito por los desarrolladores debe compilarse en una imagen de contenedor.

Puedes usar cualquier sistema que desees para compilar un contenedor. En esta página, se describen las siguientes formas de usar Cloud Build para compilar imágenes de contenedor:

Requisitos para los servicios de Cloud Run

En el caso de los servicios de Cloud Run, puedes usar imágenes de contenedor compiladas con cualquier herramienta capaz de compilar imágenes de contenedor, siempre que respeten el contrato de contenedor. En particular, tu código debe escuchar las solicitudes HTTP en el puerto que define la variable de entorno PORT. Cloud Run inserta de manera automática esta variable de entorno PORT en tu contenedor.

Antes de comenzar

  • Necesitas Google Cloud CLI para ejecutar algunos de los comandos de esta página.

  • Crea un repositorio en un registro de contenedores compatible. Para crear un repositorio de Artifact Registry, ejecuta lo siguiente:

        gcloud artifacts repositories create REPOSITORY \
            --repository-format=docker \
            --location=LOCATION \
            --description="DESCRIPTION" \
            --immutable-tags \
            --async
    
  • Puedes configurar Docker para obtener acceso a Artifact Registry a través del auxiliar de credenciales de gcloud CLI:

    gcloud auth configure-docker LOCATION-docker.pkg.dev
    Reemplaza LOCATION por el nombre de la región de tu repositorio de contenedores, por ejemplo, us-west2.

Compila con un Dockerfile

Antes de compilar las fuentes en una imagen de contenedor (“alojamiento en contenedores”) de forma local mediante Docker o Cloud Build, necesitas que haya un Dockerfile junto con tus fuentes. Las muestras de Hello World contienen aplicaciones de muestra y Dockerfiles en muchos lenguajes populares.

Si usas Dockerfiles, puedes usar cualquiera de los siguientes métodos para compilar:

  • Compila mediante Cloud Build
  • Compila de forma local mediante Docker

Compila mediante Cloud Build

Puedes compilar tu imagen en Google Cloud con Cloud Build:

  1. Navega a la carpeta que contiene tus fuentes y el Dockerfile.

  2. Ejecuta este comando:

    gcloud builds submit --tag IMAGE_URL

    Reemplaza IMAGE_URL por una referencia a la imagen de contenedor, como us-docker.pkg.dev/cloudrun/container/hello:latest. Si usas Artifact Registry, el repositorio REPO_NAME debe estar creado. La URL sigue el formato de LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG.

Si deseas obtener sugerencias para mejorar el rendimiento de la compilación, consulta Acelera las compilaciones.

Compila de forma local y realiza el envío con Docker

Si tienes Docker instalado de manera local, puedes usar docker build en lugar de Cloud Build o los paquetes de compilación de Google Cloud.

Para compilar tu imagen de contenedor mediante Docker, sigue estos pasos:

  1. Navega a la carpeta que contiene tus fuentes y el Dockerfile.

  2. Ejecuta este comando:

    docker build . --tag IMAGE_URL

    Reemplaza IMAGE_URL por una referencia a la imagen de contenedor, como us-docker.pkg.dev/cloudrun/container/hello:latest. Si usas Artifact Registry, el repositorio REPO_NAME debe estar creado. La URL sigue el formato de LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG.

    Ten en cuenta que, si usas una Mac con Apple Silicon, debes especificar --platform linux/amd64 en la línea de comandos.

  3. Envía la imagen del contenedor a un registro de contenedores compatible:

    docker push IMAGE_URL

    Reemplaza IMAGE_URL por una referencia a la imagen de contenedor, como us-docker.pkg.dev/cloudrun/container/hello:latest. Si usas Artifact Registry, el repositorio REPO_NAME debe estar creado. La URL sigue el formato de LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG.

Para excluir archivos locales de este proceso, sigue las instrucciones del archivo de configuración .dockerignore.

Compila con los paquetes de compilación de Google Cloud

Paquetes de compilación de Google Cloud es un conjunto de Buildpacks compatibles con CNCF que compilan código fuente en imágenes de contenedor diseñadas para ejecutarse en Google Cloud plataformas de contenedores, incluido Cloud Run.

Para obtener una lista de los lenguajes compatibles, consulta la documentación de paquetes de compilación de Google Cloud.

Compila con los paquetes de compilación de Google Cloud usando Cloud Build

Sigue estos pasos para compilar con los paquetes de compilación de Google Cloud:

  1. Navega a la carpeta que contiene tus fuentes.

  2. Ejecuta el siguiente comando:

    gcloud builds submit --pack image=IMAGE_URL

    Reemplaza IMAGE_URL por una referencia a la imagen de contenedor, como us-docker.pkg.dev/cloudrun/container/hello:latest. Si usas Artifact Registry, el repositorio REPO_NAME debe estar creado. La URL sigue el formato de LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG.

  3. Espera a que se complete la compilación.

Compila con los paquetes de compilación de Google Cloud a través de la línea de comandos de pack

Sigue estos pasos para compilar mediante el comando pack:

  1. Si aún no lo hiciste, instala Docker.

  2. Si aún no lo hiciste, instala pack.

  3. Navega a la carpeta que contiene tus fuentes.

  4. Ejecuta el siguiente comando para compilar y enviar a tu registro de contenedores compatible:

    pack build --publish IMAGE_URL

    Reemplaza IMAGE_URL por una referencia a la imagen de contenedor, como us-docker.pkg.dev/cloudrun/container/hello:latest. Si usas Artifact Registry, el repositorio REPO_NAME debe estar creado. La URL sigue el formato de LOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG.

  5. Espera a que pack finalice.

Para obtener más información, lee las instrucciones provistas en Compila una aplicación.

¿Qué sigue?