En esta página, se explica cómo usar Cloud Build para compilar, probar, contenerizar e implementar aplicaciones de Go, y cómo guardar tus registros de prueba en Cloud Storage.
Antes de comenzar
En las instrucciones de esta página se supone que estás familiarizado con Go. Además, ten en cuenta la siguiente información:
-
Enable the Cloud Build, Cloud Run, and Artifact Registry APIs.
- Para ejecutar los comandos de
gcloud
en esta página, instala Google Cloud CLI. - Ten a mano tu proyecto de Go.
- Si deseas contenerizar tu app en Go con Cloud Build, necesitarás un
Dockerfile
junto con tu código fuente. - Si deseas almacenar el contenedor compilado en Artifact Registry, crea un repositorio de Docker en Artifact Registry.
- Si deseas almacenar registros de prueba en Cloud Storage, crea un bucket en Cloud Storage.
Permisos de IAM obligatorios
Para almacenar registros de prueba en Logging, otorga la función creador de objetos de almacenamiento (
roles/storage.objectCreator
) en el bucket de Cloud Storage a tu cuenta de servicio de compilación.Para almacenar imágenes compiladas en Artifact Registry, otorga el rol de escritor de Artifact Registry (
roles/artifactregistry.writer
) a tu cuenta de servicio de compilación.
Si deseas obtener instrucciones para otorgar estos roles, consulta Otorga un rol con la página de IAM.
Configura compilaciones de Go
La imagen golang
pública de Docker Hub es compatible con la compilación mediante módulos de Go.
Usar esta imagen como un paso de compilación en el archivo de configuración de Cloud Build te permite invocar comandos go
dentro de la imagen. Los argumentos que se pasan a este paso de compilación se pasan directamente a la herramienta de golang
, lo que te permite ejecutar cualquier comando de go
en esta imagen.
En esta sección, se explica un ejemplo de archivo de configuración de compilación para una app de Go. Tiene pasos de compilación para compilar la app, agregar pruebas de unidades y, luego de pasar las pruebas, crear contenedores en la app y, luego, implementarla.
Para compilar la aplicación de Go, sigue estos pasos:
En el directorio raíz del proyecto, crea un archivo de configuración de Cloud Build llamado
cloudbuild.yaml
.Compila y prueba: Si definiste pruebas de unidades en tu aplicación, puedes configurar Cloud Build para que ejecute las pruebas. Para ello, agrega los siguientes campos en un paso de compilación:
name
: Configura el valor de este campo engolang
para usar la imagen de Go desde Docker Hub para tu tarea.entrypoint
: Establece el valor de este campo en/bin/bash
. Esto te permite ejecutar comandos bash de varias líneas directamente desde el paso de compilación.args
: En el campoargs
de un paso de compilación, se toma una lista de argumentos y se los pasa a la imagen a la que se hace referencia en el camponame
. En el siguiente ejemplo, el campoargs
toma los argumentos para lo siguiente:- Ejecutar el generador de registros de prueba para descargar el resultado del registro de prueba.
- Imprimir el resultado del registro.
- Guardar resultados de pruebas en
sponge.log
. - Se generan los resultados en
sponge.log
en un archivo XML JUNIT. El nombre del archivo XML de JUNIT se construye con la versión corta del ID de confirmación asociado con tu compilación. Los pasos de compilación posteriores guardarán los registros de este archivo en Cloud Storage.
Crea contenedores en la app: Después de agregar el paso de compilación a fin de garantizar que las pruebas se hayan aprobado, puedes compilar la aplicación. Cloud Build proporciona una imagen de Docker compilada con anterioridad que puedes usar para crear contenedores en tu aplicación de Go. Para organizar tu app en contenedores, agrega los siguientes campos en un paso de compilación:
name
: Configura el valor de este campo engcr.io/cloud-builders/docker
para usar la imagen de Docker compilada previamente para tu tarea.args
: Agrega los argumentos para el comandodocker build
como valores para este campo.
En el siguiente paso de compilación, se compila la imagen
myimage
y se etiqueta con la versión corta de tu ID de confirmación. En el paso de compilación, se usan sustituciones para el ID del proyecto, el nombre del repositorio y los valores cortos de SHA, por lo que estos valores se sustituyen de forma automática durante la compilación. Ten en cuenta que deberás crear o tener un repositorio de Docker existente en Artifact Registry para almacenar la imagen.Envía el contenedor a Artifact Registry: Puedes almacenar el contenedor compilado en Artifact Registry, que es un Google Cloud servicio que puedes usar para almacenar, administrar y proteger artefactos de compilación. Para hacer esto, deberás tener un repositorio de Docker existente en Artifact Registry. Para configurar Cloud Build a fin de almacenar la imagen en un repositorio de Docker de Artifact Registry, agrega un paso de compilación con los siguientes campos:
name
: Establece el valor de este campo engcr.io/cloud-builders/docker
para usar la imagen oficial del compiladordocker
en tu tarea.args
: Agrega los argumentos para el comandodocker push
como valores de este campo. Para la URL de destino, ingresa el repositorio de Docker de Artifact Registry en el que deseas almacenar la imagen.
En el siguiente paso de compilación, se envía la imagen que compilaste en el paso anterior a Artifact Registry:
Implementa el contenedor en Cloud Run: Para implementar la imagen en Cloud Run, agrega un paso de compilación con los siguientes campos:
name
: Configura el valor de este campo engoogle/cloud-sdk
para usar la imagen de gcloud CLI y, luego, invocar el comandogcloud
para implementar la imagen en Cloud Run.args
: Agrega los argumentos para el comandogcloud run deploy
como los valores de este campo.
En el siguiente paso de compilación, se implementa la imagen compilada con anterioridad en Cloud Run:
Guardar registros de prueba en Cloud Storage: Puedes configurar Cloud Build para almacenar cualquier registro de prueba en Cloud Storage si especificas una ubicación de bucket existente y una ruta de acceso a los registros de prueba.
En el siguiente paso de compilación, se almacenan los registros de prueba que guardaste en el archivo XML JUNIT en un bucket de Cloud Storage:
En el siguiente fragmento, se muestra el archivo de configuración de compilación completo para los pasos anteriores:
Inicia la compilación con la CLI de gcloud o los activadores de compilación. Debes especificar el nombre del repositorio de Artifact Registry cuando inicies la compilación.
Para especificar el repositorio de Artifact Registry cuando inicies la compilación con gcloud CLI, haz lo siguiente:
gcloud builds submit --region=us-west2 --config=cloudbuild.yaml \ --substitutions=_AR_REPO_NAME="AR_REPO_NAME"
Reemplaza
AR_REPO_NAME
por el nombre de tu repositorio de Artifact Registry.Para especificar el repositorio de Artifact Registry cuando compilas con activadores de compilación, especifica el nombre de tu repositorio de Artifact Registry en el campo Variables de sustitución cuando creas el activador de compilación.
¿Qué sigue?
- Obtén más información para realizar implementaciones azul-verde en Compute Engine.
- Obtén más información sobre cómo compilar imágenes de contenedores.
- Obtén más información para solucionar errores de compilación.