Pianificare una funzione Cloud Run HTTP


Questo tutorial mostra come attivare una funzione Cloud Run HTTP utilizzando Cloud Scheduler e scegliendo come target un endpoint HTTP. Utilizza una funzione HTTP quando è necessario che la funzione abbia un endpoint URL e risponda alle richieste HTTP, come per i webhook.

Tieni presente che puoi anche pianificare una funzione basata su eventi quando deve essere attivata direttamente in risposta agli eventi all'interno del un progetto Google Cloud, ad esempio i messaggi su un argomento Pub/Sub o le modifiche nel bucket Cloud Storage. Per ulteriori informazioni, vedi Tipi di funzioni di Cloud Run.

La pianificazione dell'esecuzione di una funzione Cloud Run è un'attività e il caso d'uso di Cloud Scheduler. In questo tutorial, imparerai a:

  1. Creare una funzione Cloud Run HTTP semplice.
  2. Creare un job Cloud Scheduler.
  3. Esegui il job Cloud Scheduler.
  4. Verifica che la funzione Cloud Run sia stata attivata dal job Cloud Scheduler.

Costi

In questo documento utilizzi i seguenti componenti fatturabili di Google Cloud:

Per generare una stima dei costi basata sull'utilizzo previsto, utilizza il Calcolatore prezzi. I nuovi utenti di Google Cloud potrebbero essere idonei per una prova gratuita.

Prima di iniziare

  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 Cloud Build, Cloud Functions, Cloud Run Admin, Cloud Scheduler APIs.

    Enable the APIs

  5. Create a service account:

    1. In the Google Cloud console, go to the Create service account page.

      Go to Create service account
    2. Select your project.
    3. In the Service account name field, enter a name. The Google Cloud console fills in the Service account ID field based on this name.

      In the Service account description field, enter a description. For example, Service account for quickstart.

    4. Click Create and continue.
    5. Grant the Cloud Run > Cloud Run Invoker role to the service account.

      To grant the role, find the Select a role list, then select Cloud Run > Cloud Run Invoker.

    6. Click Continue.
    7. Click Done to finish creating the service account.

  6. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

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

  8. Enable the Cloud Build, Cloud Functions, Cloud Run Admin, Cloud Scheduler APIs.

    Enable the APIs

  9. Create a service account:

    1. In the Google Cloud console, go to the Create service account page.

      Go to Create service account
    2. Select your project.
    3. In the Service account name field, enter a name. The Google Cloud console fills in the Service account ID field based on this name.

      In the Service account description field, enter a description. For example, Service account for quickstart.

    4. Click Create and continue.
    5. Grant the Cloud Run > Cloud Run Invoker role to the service account.

      To grant the role, find the Select a role list, then select Cloud Run > Cloud Run Invoker.

    6. Click Continue.
    7. Click Done to finish creating the service account.

  10. Tieni presente che devi concedere il ruolo Invoker di Cloud Run perché in Funzioni di Cloud Run (2ª generazione), le autorizzazioni di chiamata sono disponibili gestendo l'elemento dal servizio Cloud Run.

  11. Per impostazione predefinita, le funzioni Cloud Run utilizzano l'account di servizio Compute Engine predefinito creato automaticamente per il proprio account di servizio di runtime. Puoi usare questo account di servizio per fare una prova questo tutorial. Tuttavia, a seconda della configurazione dei criteri dell'organizzazione, all'account di servizio predefinito potrebbe non essere concesso automaticamente il ruolo Editor su del tuo progetto. In questo caso, devi concedere all'account di servizio i seguenti ruoli:
    1. Writer Artifact Registry (roles/artifactregistry.writer)
    2. Writer log (roles/logging.logWriter)
    3. Storage Object Viewer (roles/storage.objectViewer)

crea una funzione Cloud Run HTTP

Creare una funzione HTTP che viene attivata da Cloud Scheduler.

  1. Nella console Google Cloud, vai alla pagina Funzioni Cloud Run.

    Vai alle funzioni Cloud Run

  2. Fai clic su Crea funzione.

  3. Nella sezione Nozioni di base:

    1. Nell'elenco Ambiente, seleziona Funzione Cloud Run.
    2. Inserisci un nome per la funzione.
    3. Nell'elenco Regione, seleziona una regione.
  4. Nella sezione Trigger, segui questi passaggi:

    1. Nell'elenco Tipo di trigger, seleziona HTTPS.
    2. Per l'autenticazione, seleziona Richiedi l'autenticazione.

      Per ulteriori informazioni, consulta Eseguire l'autenticazione per l'invocazione (2ª gen.).

  5. Accetta gli altri valori predefiniti e fai clic su Avanti.

  6. Non modificare la lingua e il codice di esempio del runtime predefiniti. Il codice non utilizza servizi cloud e non richiede l'attivazione di autorizzazioni aggiuntive. Fai clic su Esegui il deployment.

  7. Una volta eseguito il deployment della funzione, fai clic sulla scheda Trigger.

  8. Copia l'URL HTTP della funzione.

Crea un job Cloud Scheduler

Crea un job Cloud Scheduler che attiva un'azione utilizzando HTTP.

  1. Nella console Google Cloud, vai alla pagina Cloud Scheduler.

    Vai a Cloud Scheduler

  2. Fai clic su Crea job.

  3. Inserisci un nome per il job.

  4. Nell'elenco Regione, seleziona una regione.

  5. Specifica la frequenza per il job, utilizzando un formato unix-cron:

    30 16 * * 7
    

    Per ulteriori informazioni, vedi Formato del job di cron e fuso orario.

  6. Nell'elenco Fuso orario, seleziona un fuso orario.

  7. Fai clic su Continua.

  8. Nell'elenco Tipo di destinazione, seleziona HTTP.

  9. Nel campo URL, inserisci l'URL HTTP della funzione che hai precedentemente copiato.

  10. Nell'elenco Intestazione di autenticazione, seleziona Aggiungi token OIDC.

  11. Nell'elenco Account di servizio, seleziona l'account di servizio che hai usato in precedenza è stato creato.

  12. Nel campo Pubblico, inserisci l'URL HTTP della funzione che hai copiato in precedenza.

  13. Fai clic su Crea.

Hai creato un cron job che esegue la funzione Cloud Run alle 16:30 del giorno Ogni domenica.

Esegui il job Cloud Scheduler

Ora puoi eseguire il job che hai creato.

  1. Nella console Google Cloud, vai alla pagina Cloud Scheduler.

    Vai a Cloud Scheduler

  2. Seleziona la casella di controllo in corrispondenza del job che hai creato e fai clic su Forza esecuzione.

    Quando viene richiamato inizialmente, il primo job creato in un progetto può assumere minuti per la configurazione e l'esecuzione.

  3. Dopo l'esecuzione del job, lo Stato dell'ultima esecuzione dovrebbe indicare Success.

Verifica i risultati nelle funzioni Cloud Run

Puoi verificare che la funzione Cloud Run sia stata attivata correttamente ed eseguito dal tuo cron job.

  1. Nella console Google Cloud, vai alla pagina Funzioni Cloud Run.

    Vai alle funzioni Cloud Run

  2. Fai clic sul nome della funzione.

    Si apre la pagina Dettagli funzione e il grafico Chiamate/secondo mostra la prima chiamata della funzione.

  3. Fai clic sulla scheda Log.

    Dovresti visualizzare una voce di log simile a POST 200 146 B 5 ms Google-Cloud-Scheduler https://REGION-PROJECT_ID.cloudfunctions.net/FUNCTION_NAME

Esegui la pulizia

Per evitare che al tuo account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questo tutorial, elimina il progetto che contiene le risorse oppure mantieni il progetto ed elimina le singole risorse.

Elimina progetto

  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.

Elimina le risorse del tutorial

  1. Nella console Google Cloud, vai alla pagina Cloud Scheduler.

    Vai a Cloud Scheduler

  2. Seleziona la casella di controllo accanto al job.

  3. Fai clic su Elimina e conferma l'eliminazione dei dati.

  4. Nella console Google Cloud, vai alla pagina Funzioni di Cloud Run.

    Vai alle funzioni Cloud Run

  5. Seleziona la casella di controllo accanto alla funzione.

  6. Fai clic su Elimina e conferma l'eliminazione.

  7. Nella console Google Cloud, vai alla pagina Account di servizio.

    Vai a Service account

  8. Seleziona la casella di controllo accanto all'account di servizio che hai creato.

  9. Fai clic su Elimina e conferma l'eliminazione dei dati.

Passaggi successivi