Crea un flujo de trabajo con Terraform
En esta guía de inicio rápido, se muestra cómo crear, implementar y ejecutar tu primer flujo de trabajo con Terraform. Terraform es una herramienta de infraestructura como código que te permite crear, cambiar y mejorar de forma predecible tu infraestructura de nube mediante código. Obtén información para usar Terraform y aprovisionar infraestructura en Google Cloud.
En esta guía de inicio rápido, el flujo de trabajo de ejemplo envía una solicitud a una API pública y, luego, muestra la respuesta de la API.
Completarás lo siguiente:
- Habilita la API de Workflows con Terraform.
- Crea una cuenta de servicio para el flujo de trabajo con Terraform.
- Definir e implementar un flujo de trabajo con Terraform
- Ejecuta el flujo de trabajo con Google Cloud CLI.
Antes de comenzar
Es posible que las restricciones de seguridad que define tu organización no te permitan completar los siguientes pasos. Para obtener información sobre la solución de problemas, consulta Desarrolla aplicaciones en un entorno de Google Cloud restringido.
Ten en cuenta que Cloud Shell ya tiene integrado Terraform. Si necesitas instalar Terraform, consulta la documentación de Terraform de HashiCorp.
- 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.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Create or select a Google Cloud project.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Resource Manager and Identity and Access Management (IAM) APIs:
gcloud services enable cloudresourcemanager.googleapis.com
iam.googleapis.com - Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Create or select a Google Cloud project.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Resource Manager and Identity and Access Management (IAM) APIs:
gcloud services enable cloudresourcemanager.googleapis.com
iam.googleapis.com
Crea un archivo de configuración de Terraform
Crea un archivo de configuración de Terraform llamado main.tf
y, luego, incluye los recursos del Proveedor de Google para Terraform que se usan en esta guía de inicio rápido.
Ten en cuenta que puedes usar la interpolación para sustituciones como variables de referencia, atributos de recursos y funciones de llamada.
Crea un directorio:
mkdir terraform
Ve al directorio
terraform
:cd terraform
Agrega un archivo nuevo,
main.tf
, al directorio:nano main.tf
Agrega los siguientes recursos al archivo
main.tf
:Asigna el ID del proyecto:
provider "google" { project = "PROJECT_ID" }
Reemplaza
PROJECT_ID
por el ID del proyecto.Habilita la API de Workflows:
Crea una cuenta de servicio para el flujo de trabajo:
Define el flujo de trabajo con el recurso
google_workflows_workflow
:En el flujo de trabajo de ejemplo, se usan los siguientes argumentos:
name
: El nombre de tu flujo de trabajo.region
: La ubicación de tu flujo de trabajo.description
: Es una descripción de tu flujo de trabajo.service_account
: Es la dirección de correo electrónico o el ID único de la cuenta de servicio asociada con la versión más reciente del flujo de trabajo. Esta cuenta de servicio representa la identidad del flujo de trabajo y determina qué permisos tiene. Si no especificas una cuenta de servicio durante la creación del flujo de trabajo, este usa la cuenta de servicio predeterminada de Compute Engine para su identidad. Para obtener más información, consulta Cómo otorgar permiso a un flujo de trabajo para acceder a recursos de Google Cloud.labels
: Es una lista de pares de etiquetas clave-valor que se asignarán a este flujo de trabajo para ayudarte a organizar tus instancias de Google Cloud. Para obtener más información, consulta ¿Qué son las etiquetas?user_env_vars
: Son variables de entorno definidas por el usuario asociadas con esta revisión del flujo de trabajo. Para obtener más información, consulta Usa variables de entorno.source_contents
: Es el código de Workflows que se ejecutará. Para conocer el límite de tamaño de archivo, consulta Límites de recursos.
Entre otros argumentos opcionales, se incluyen los siguientes:
crypto_key_name
: El ID de recurso de una clave de Cloud Key Management Service en el siguiente formato:projects/PROJECT_NAME/locations/LOCATION/keyRings/KEY_RING/cryptoKeys/KEY_NAME
Para obtener más información, consulta Usa claves de encriptación administradas por el cliente.
call_log_level
: Es el nivel de registro que se aplicará a las llamadas y las respuestas de llamadas durante las ejecuciones de este flujo de trabajo. Los valores posibles son:CALL_LOG_LEVEL_UNSPECIFIED
LOG_ALL_CALLS
LOG_ERRORS_ONLY
LOG_NONE
Para obtener más información, consulta Registro de llamadas.
project
: Es el ID del proyecto al que pertenece el recurso. Si no se proporciona, se usa el proyecto del proveedor.name_prefix
: Crea un nombre único que comienza con el prefijo especificado. Si no se especifican este valor yname
, se elige un valor aleatorio para el nombre.
Crea y ejecuta el flujo de trabajo
Implementa tus recursos de Terraform para crear el flujo de trabajo y, luego, ejecútalo.
Inicializa Terraform en el directorio:
terraform init
Verifica que los cambios que propones con Terraform coincidan con el plan esperado:
terraform plan
Puedes ignorar la nota sobre no usar la opción
-out
.Crea el flujo de trabajo:
terraform apply
En el mensaje Ingresa un valor, escribe
yes
para continuar con la creación de los recursos.Confirma que se haya creado un flujo de trabajo:
gcloud workflows list --location us-central1
El resultado debería ser similar al siguiente ejemplo:
NAME STATE REVISION_ID UPDATE_TIME projects/project-name/locations/us-central1/workflows/sample-workflow ACTIVE 000001-f9a 2024-02-24T13:38:58.353765906Z
De manera opcional, puedes ejecutar el flujo de trabajo:
gcloud workflows execute sample-workflow
Realiza una limpieza
Para evitar que se apliquen cargos a tu cuenta de Google Cloud por los recursos que se usaron en esta página, borra el proyecto de Cloud que tiene los recursos.
- Borra todos los recursos que creaste con Terraform:
terraform destroy
- Borra el flujo de trabajo que creaste:
Cuando se te pregunte si deseas continuar, ingresagcloud workflows delete sample-workflow
y
. - Como alternativa, puedes borrar el proyecto de Google Cloud para evitar que se generen cargos. Si borras tu proyecto de Google Cloud, se dejan de facturar todos los recursos que usaste en ese proyecto.
Delete a Google Cloud project:
gcloud projects delete PROJECT_ID
¿Qué sigue?
Salvo que se indique lo contrario, el contenido de esta página está sujeto a la licencia Atribución 4.0 de Creative Commons, y los ejemplos de código están sujetos a la licencia Apache 2.0. Para obtener más información, consulta las políticas del sitio de Google Developers. Java es una marca registrada de Oracle o sus afiliados.
Última actualización: 2024-12-22 (UTC)