Trigger di Cloud Storage
Nelle funzioni di Cloud Run, un trigger di Cloud Storage consente di chiamare una funzione in risposta ai cambiamenti in Cloud Storage. Quando un trigger Cloud Storage per una funzione, scegli un evento digita e specifica un bucket Cloud Storage. La tua funzione verrà chiamata ogni volta che si verifica una modifica su un oggetto (file) all'interno del bucket specificato.
Sono supportati i seguenti tipi di eventi di Cloud Storage:
Evento | Tipo di evento | Descrizione |
---|---|---|
Oggetto completato |
|
Si verifica quando viene creato un nuovo oggetto o quando un oggetto esistente sovrascritto e ne viene creata una nuova generazione. |
Oggetto eliminato |
|
Si verifica quando un oggetto viene eliminato definitivamente. |
Oggetto archiviato |
|
Si verifica quando una versione attiva di un oggetto diventa una versione non corrente. Per ulteriori informazioni, consulta Controllo delle versioni degli oggetti. |
Metadati dell'oggetto aggiornati |
|
Si verifica quando i metadati di un modifiche esistenti all'oggetto. |
Un trigger di Cloud Storage viene implementato come
Funzione CloudEvent,
in cui i dati degli eventi Cloud Storage vengono passati alla funzione in
il formato CloudEvents e i dati di CloudEvent
il payload è di tipo
StorageObjectData
.
La Google Eventi contiene risorse aggiuntive per lavorare con i dati sugli eventi.
Autorizzazioni
Per utilizzare i trigger di Cloud Storage nelle funzioni di Cloud Run,
l'agente di servizio Cloud Storage
devi avere il publisher Pub/Sub
(roles/pubsub.publisher
)
ruolo IAM per il tuo progetto.
Deployment
Puoi specificare un trigger di Cloud Storage quando esegui il deployment di una funzione. Consulta Eseguire il deployment di una funzione Cloud Run per istruzioni generali su come eseguire il deployment di una funzione e consulta quanto segue per informazioni aggiuntive specifiche sulla configurazione degli attivatori Cloud Storage durante il deployment.
gcloud
Se esegui il deployment utilizzando l'interfaccia a riga di comando gcloud, puoi utilizzare il tipo di evento Object finalized (Oggetto completato) di Cloud Storage con i seguenti flag:
gcloud functions deploy YOUR_FUNCTION_NAME \ --trigger-bucket=YOUR_STORAGE_BUCKET \ [--retry] \ ...
- Il flag
--trigger-bucket
specifica il bucket Cloud Storage che verrà monitorato dall'attivatore. Gli eventi finali dell'oggetto all'interno di questo bucket attiveranno le chiamate al tuo personalizzata. - Il
--retry
flag controlla se le chiamate di funzione non riuscite vengono tentate automaticamente di nuovo. Consulta Ripetere le funzioni basate su eventi per ulteriori informazioni.
Per utilizzare tipi di eventi diversi da Object finalized (Oggetto completato), utilizza i seguenti flag:
gcloud functions deploy YOUR_FUNCTION_NAME
--gen2
--trigger-event-filters="type=EVENT_TYPE"
--trigger-event-filters="bucket=YOUR_STORAGE_BUCKET"
...
Quando esegui il deployment delle funzioni, specifica solo il nome del bucket senza
gs://
in testa; ad esempio
--trigger-event-filters="bucket=my-bucket"
.
Console
Se esegui il deployment utilizzando la console Google Cloud, puoi configurare un attivatore Cloud Storage nella sezione Attivati:
- Nel campo Tipo di trigger, scegli Cloud Storage.
Nel campo Tipo di evento, scegli un evento di attivazione. Il valore predefinito è
google.cloud.storage.object.v1.finalized
.Per un evento Cloud Storage che utilizza Cloud Audit Logs, consulta le istruzioni di configurazione dell'attivatore per un trigger Eventarc.
Nel campo Bucket, fai clic su Sfoglia per selezionare un bucket Cloud Storage da monitorare dall'attivatore. Le modifiche agli oggetti all'interno di questo bucket attiveranno le chiamate alla funzione.
Seleziona o deseleziona la casella di controllo Riprova in caso di errore per controllare se Cloud Run esegue automaticamente un nuovo tentativo di una funzione non riuscita invocazione. Consulta Ripetere le funzioni basate su eventi per ulteriori informazioni.
Fai clic su Altre opzioni per eseguire una configurazione aggiuntiva sull'attivatore:
Nel campo Tipo di attivatore, specifica una delle origini Google, Personalizzato o di terze parti:
Le origini Google ti consentono di specificare gli attivatori per Pub/Sub, Cloud Storage, Firestore e altri fornitori di eventi Google. Nel riquadro Trigger Eventarc, utilizza il campo Fornitore di eventi per selezionare il prodotto che fornisce il tipo di evento con cui vuoi attivare la funzione. Quindi, nel campo Evento, seleziona l'evento da utilizzare come trigger.
L'opzione Personalizzato ti consente di produrre e utilizzare eventi da del codice della tua applicazione. Segui le istruzioni nel riquadro Trigger Eventarc per creare un canale. Un canale è una risorsa utilizzata come pipeline per pubblicare eventi personalizzati dai produttori ai consumatori. Gli eventi personalizzati vengono pubblicati in un canale e un trigger Eventarc si iscrive a questi eventi.
L'opzione Di terze parti ti consente di eseguire l'integrazione con che offrono un'origine Eventarc. Consulta eventi di terze parti in Eventarc per maggiori dettagli.
Nel campo Evento, seleziona un evento di attivazione. Il valore predefinito è
google.cloud.storage.object.v1.finalized
.Se vuoi, nel campo Account di servizio, seleziona un account di servizio da utilizzare come identità dell'attivatore Eventarc. Per ulteriori informazioni, consulta Identità trigger.
Fai clic su Salva trigger.
Consegna di eventi
Gli attivatori Cloud Storage vengono implementati con le notifiche Pub/Sub per Cloud Storage. Gli eventi sono soggetti a Garanzie di consegna delle notifiche Pub/Sub.
Un bucket Cloud Storage può avere fino a 10 configurazioni di notifica per un evento specifico. Superamento dei limiti di notifiche del bucket causerà l'errore di ulteriori deployment delle funzioni, con un errore come il seguente:
Cloud Storage bucket ...: Pub/Sub notification limit reached
Per saperne di più, consulta Quote e limiti di Cloud Storage.
Passaggi successivi
- Scopri come scrivere funzioni basate su eventi.
- Scopri come eseguire il deployment di una funzione Cloud Run.
- Consulta il tutorial sulle funzioni Cloud Storage per un esempio di scrittura, deployment e chiamata di una funzione con un trigger Cloud Storage.