Pianifica ed esegui un cron job utilizzando Terraform
Questa guida rapida mostra come utilizzare Terraform per creare un cron job Cloud Scheduler. Terraform è uno strumento Infrastructure as Code (IaC) che consente di creare, modificare e migliorare in modo prevedibile l'infrastruttura cloud utilizzando il codice. Puoi scoprire di più sull'utilizzo di Terraform per il provisioning dell'infrastruttura su Google Cloud.
Cloud Scheduler prevede un Livello gratuito e l'esecuzione di questa guida rapida non dovrebbe comportare alcun costo. Per ulteriori informazioni, vedi Prezzi.
In questa guida rapida:
- Utilizza Terraform per creare un cron job per Cloud Scheduler.
- Imposta una programmazione ricorrente per il job.
- Specificare un argomento Pub/Sub come target del job.
- Esegui il job.
- Verificare che il job sia stato eseguito correttamente.
Prima di iniziare
-
Sign in to your Google Account.
If you don't already have one, sign up for a new account.
-
Install the Google Cloud CLI.
-
Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata.
-
Per inizializzare gcloud CLI, esegui questo comando:
gcloud init
-
Create or select a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator
), which contains theresourcemanager.projects.create
permission. Learn how to grant roles.
-
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.
-
Install the Google Cloud CLI.
-
Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata.
-
Per inizializzare gcloud CLI, esegui questo comando:
gcloud init
-
Create or select a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator
), which contains theresourcemanager.projects.create
permission. Learn how to grant roles.
-
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.
- Cloud Shell ha già integrato Terraform. Se devi installare Terraform, consulta la documentazione di HashiCorp Terraform.
Apri un terminale e crea una directory:
mkdir terraform
Vai alla directory
terraform
:cd terraform
Aggiungi un nuovo file,
main.tf
, alla directory:nano main.tf
Aggiungi le seguenti risorse del provider Terraform per Google Cloud al file
main.tf
:Abilita le API Cloud Scheduler e Pub/Sub:
Crea un argomento Pub/Sub come risorsa a cui i publisher possono inviare messaggi:
Viene creato un argomento denominato
pubsub_topic
.Crea una sottoscrizione per ricevere i messaggi pubblicati nell'argomento Pub/Sub:
Crea un cron job utilizzando la risorsa
google_cloud_scheduler_job
:Nell'esempio vengono utilizzati i seguenti argomenti:
name
: il nome del job.description
: una descrizione del lavoro.schedule
: la frequenza del job, utilizzando un formato basato su unix-cron.In questo esempio,
30 16 * * 7
significa che il job verrà eseguito alle 16:30 di domenica. Per saperne di più, consulta Formato cron job e fuso orario.region
: la regione in cui si trova il job.pubsub_target
: la destinazione dell'argomento Pub/Sub, incluso il nome completo della risorsa dell'argomento (topic_name
) a cui viene pubblicato il payload del messaggio (data
) quando viene eseguito il job.
Sono supportati altri argomenti. Per maggiori dettagli, consulta le Informazioni di riferimento sugli argomenti del registro Terraform.
Apri un terminale e, nella directory
terraform
, inizializza Terraform:terraform init
Verifica che le modifiche che proponi con Terraform corrispondano al piano previsto:
terraform plan
Puoi ignorare la nota relativa al mancato utilizzo dell'opzione
-out
.Crea il cron job:
terraform apply
Al prompt Inserisci un valore, digita
yes
per procedere con la creazione delle risorse.Verifica che sia stato creato un job:
gcloud scheduler jobs describe test-job --location=us-central1
L'output dovrebbe essere simile al seguente:
description: test job lastAttemptTime: '2024-04-04T13:56:00.669530Z' name: projects/PROJECT_ID/locations/us-central1/jobs/test-job pubsubTarget: data: dGVzdA== topicName: projects/PROJECT_ID/topics/pubsub_topic schedule: '30 16 * * 7' scheduleTime: '2024-04-04T13:58:00.737907Z' state: ENABLED
Esegui il pull dei messaggi Pub/Sub da una sottoscrizione:
gcloud pubsub subscriptions pull pubsub_subscription --limit 5
Se inizialmente non vengono estratti messaggi, esegui di nuovo il comando.
Visualizza i risultati dell'esecuzione del job. L'output dovrebbe essere simile al seguente:
DATA: Hello world! MESSAGE_ID: 5028933846601543 ORDERING_KEY: ATTRIBUTES: DELIVERY_ATTEMPT: ACK_ID: RFAGFixdRkhRNxkIaFEOT14jPzUgKEUQAgVPAihdeTFXLkFacGhRDRlyfWB9[...]
- L'eliminazione del tuo progetto Google Cloud interrompe la fatturazione per tutte le risorse utilizzate al suo interno. Tieni presente che, per impostazione predefinita, tutti i file nella home directory di Cloud Shell (ad esempio, tutti i file Terraform) persistono tra le sessioni.
Delete a Google Cloud project:
gcloud projects delete PROJECT_ID
In alternativa, puoi eliminare tutte le risorse che hai creato con Terraform.
Il comando
terraform destroy
termina tutte le risorse specificate nel tuo stato Terraform. Non elimina le risorse non gestite dal progetto Terraform corrente. Il file di configurazione Terraform non viene eliminato. Per ulteriori informazioni, consulta la sezione Distruggere l'infrastruttura.terraform destroy
Crea un file di configurazione Terraform
Per utilizzare Terraform con Cloud Scheduler, devi creare un file di configurazione per descrivere la tua infrastruttura e creare un piano di esecuzione. Applica quindi il file di configurazione alla tua piattaforma o al tuo servizio per eseguire operazioni che eseguono il provisioning dell'infrastruttura.
Completa i seguenti passaggi per creare un file di configurazione Terraform denominato
main.tf
:
Crea il cron job
Esegui il deployment delle risorse Terraform per creare il job cron.
Hai creato un job che invia un messaggio a un argomento Pub/Sub alle 16:30 di domenica. Ora puoi eseguire il job.
Esegui il job
Oltre a essere eseguito in base alla pianificazione specificata, puoi forzare l'esecuzione immediata del job eseguendo il comando seguente.
gcloud scheduler jobs run test-job --location=us-central1
Tieni presente che, a causa della configurazione iniziale, l'esecuzione del primo job creato in un progetto può richiedere alcuni minuti.
Verifica i risultati
Verifica che l'argomento Pub/Sub riceva messaggi dal job.
Esegui la pulizia
Per evitare che al tuo account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questa pagina, elimina il progetto Google Cloud con le risorse.