Accoda le funzioni con Cloud Tasks


Le funzioni di coda delle attività sfruttano Google Cloud Tasks per aiutare la tua app a eseguire attività che richiedono molto tempo, molte risorse o una larghezza di banda limitata in modo asincrono, al di fuori del flusso principale dell'applicazione.

Ad esempio, supponiamo di voler creare backup di un ampio insieme di file immagine attualmente ospitati su un'API con un limite di frequenza. Per essere un consumer responsabile di questa API, devi rispettare i limiti di frequenza. Inoltre, questo tipo di job a esecuzione prolungata potrebbe essere vulnerabile a errori dovuti a timeout e limiti di memoria.

Per ridurre questa complessità, puoi scrivere una funzione di coda delle attività che imposta le opzioni di base delle attività come scheduleTime e dispatchDeadline, quindi passa la funzione a una coda in Cloud Tasks. L'ambiente Cloud Tasks è progettato specificamente per garantire un controllo efficace della congestione e politiche di ripetizione per questi tipi di operazioni.

L'SDK Firebase per Cloud Functions for Firebase versione 3.20.1 e successive interagisce con Firebase Admin SDK versione 10.2.0 e successive per supportare le funzioni della coda di attività.

L'utilizzo delle funzioni di coda delle attività con Firebase può comportare addebiti per l'elaborazione di Cloud Tasks. Per ulteriori informazioni, consulta la pagina relativa ai prezzi di Cloud Tasks.

Crea funzioni di coda delle attività

Per utilizzare le funzioni della coda di attività, segui questo flusso di lavoro:

  1. Scrivi una funzione di coda di attività utilizzando l'SDK Firebase per Cloud Functions.
  2. Testa la funzione attivandola con una richiesta HTTP.
  3. Esegui il deployment della funzione con la CLI Firebase. Quando esegui il deployment della funzione di coda delle attività per la prima volta, la CLI crea una coda delle attività in Cloud Tasks con le opzioni (limitazione della frequenza e nuovi tentativi) specificate nel codice sorgente.
  4. Aggiungi attività alla coda di attività appena creata, passando i parametri per configurare una pianificazione di esecuzione, se necessario. Puoi farlo scrivendo il codice utilizzando Admin SDK e implementandolo in Cloud Functions for Firebase.

Scrivi funzioni di code di attività

Utilizza onDispatch per iniziare a scrivere funzioni di code di attività. Una parte importante della scrittura di una funzione di coda delle attività è l'impostazione della configurazione di limitazione della frequenza e dei tentativi per coda. Gli esempi di codice in questa pagina si basano su un'app che configura un servizio che esegue il backup di tutte le immagini della Astronomy Picture of the Day della NASA:

Configura le funzioni della coda di attività

Le funzioni della coda di attività sono dotate di un potente insieme di impostazioni di configurazione per controllare con precisione i limiti di frequenza e il comportamento di nuovi tentativi di una coda di attività:

exports.backupApod = functions
    .runWith( {secrets: ["NASA_API_KEY"]})
    .tasks.taskQueue({
      retryConfig: {
        maxAttempts: 5,
        minBackoffSeconds: 60,
      },
      rateLimits: {
        maxConcurrentDispatches: 6,
      },
    }).onDispatch(async (data) => {
  • retryConfig.maxAttempts=5: ogni attività nella coda delle attività viene ritentata automaticamente fino a 5 volte. Ciò contribuisce a mitigare gli errori temporanei, come gli errori di rete o l'interruzione temporanea del servizio di un servizio esterno dipendente.
  • retryConfig.minBackoffSeconds=60: Ogni attività viene riprovata ad almeno 60 secondi di distanza da ogni tentativo. In questo modo, viene fornito un ampio buffer tra ogni tentativo per non esaurire troppo rapidamente i 5 tentativi.
  • rateLimits.maxConcurrentDispatch=6: vengono inviate al massimo 6 attività alla volta. Ciò contribuisce a garantire un flusso costante di richieste alla funzione sottostante e a ridurre il numero di istanze attive e avvii a freddo.

Testare le funzioni della coda di attività

Nella maggior parte dei casi, l'emulatore Cloud Functions è il modo migliore per testare le funzioni della coda delle attività. Consulta la documentazione di Emulator Suite per scoprire come strumentare la tua app per l'emulazione delle funzioni della coda di attività.

Inoltre, le funzioni della coda di attività sono esposte come semplici funzioni HTTP in Firebase Local Emulator Suite. Puoi testare una funzione di attività emulata inviando una richiesta HTTP POST con un payload di dati JSON:

 # start the Firebase Emulators
 firebase emulators:start

 # trigger the emulated task queue function
 curl \
  -X POST                                            # An HTTP POST request...
  -H "content-type: application/json" \              # ... with a JSON body
  http://localhost:$PORT/$PROJECT_ID/$REGION/$NAME \ # ... to function url
  -d '{"data": { ... some data .... }}'              # ... with JSON encoded data

Esegui il deployment delle funzioni della coda di attività

Esegui il deployment della funzione di coda delle attività utilizzando l'interfaccia a riga di comando di Firebase:

$ firebase deploy --only functions:backupApod

Quando esegui il deployment di una funzione di coda delle attività per la prima volta, la CLI crea una coda delle attività in Cloud Tasks con le opzioni (limitazione della frequenza e nuovi tentativi) specificate nel codice sorgente.

Se si verificano errori di autorizzazione durante il deployment delle funzioni, assicurati che all'utente che esegue i comandi di deployment siano assegnati i ruoli IAM appropriati.

Mettere in coda le funzioni della coda di attività

Le funzioni della coda delle attività possono essere inserite in coda in Cloud Tasks da un ambiente server attendibile come Cloud Functions for Firebase utilizzando Firebase Admin SDK per Node.js. Se non hai mai utilizzato Admin SDK, consulta Aggiungere Firebase a un server per iniziare.

In un flusso tipico, Admin SDK crea una nuova attività, la mette in coda in Cloud Tasks e imposta la configurazione per l'attività:

exports.enqueueBackupTasks = functions.https.onRequest(
async (_request, response) => {
  const queue = getFunctions().taskQueue("backupApod");
  const enqueues = [];
  for (let i = 0; i <= 10; i += 1) {
    // Enqueue each task with i*60 seconds delay. Our task queue function
    // should process ~1 task/min.
    const scheduleDelaySeconds = i * 60 
    enqueues.push(
        queue.enqueue(
          { id: `task-${i}` },
          {
            scheduleDelaySeconds,
            dispatchDeadlineSeconds: 60 * 5 // 5 minutes
          },
        ),
    );
  }
  await Promise.all(enqueues);
  response.sendStatus(200);

});
  • scheduleDelaySeconds: il codice campione tenta di distribuire l'esecuzione delle attività associando un ritardo di N minuti per l'N-esima attività. Ciò si traduce nell'attivazione di circa 1 attività al minuto. Tieni presente che puoi anche utilizzare scheduleTime se vuoi che Cloud Tasks attivi un'attività a un'ora specifica.
  • dispatchDeadlineSeconds: Quantità massima di tempo Cloud Tasks attenderà il completamento di un'attività. Cloud Tasks riproverà l'attività in base alla configurazione dei nuovi tentativi della coda o fino al raggiungimento di questa scadenza. Nell'esempio, la coda è configurata per riprovare l'attività fino a 5 volte, ma l'attività viene annullata automaticamente se l'intero processo (inclusi i tentativi) richiede più di 5 minuti.

Risoluzione dei problemi

Attivare la registrazione dei log di Cloud Tasks

I log di Cloud Tasks contengono informazioni diagnostiche utili, come lo stato della richiesta associata a un'attività. Per impostazione predefinita, i log di Cloud Tasks sono disattivati a causa del volume elevato di log che possono potenzialmente generare nel tuo progetto. Ti consigliamo di attivare i log di debug mentre sviluppi e esegui il debug delle funzioni della coda di attività. Vedi Attivazione della registrazione.

Autorizzazioni IAM

Potresti visualizzare errori PERMISSION DENIED durante l'accodamento delle attività o quando Cloud Tasks tenta di richiamare le funzioni della coda di attività. Assicurati che il tuo progetto disponga dei seguenti binding IAM:

  • L'identità utilizzata per accodare le attività a Cloud Tasks deve disporre dell'autorizzazione IAM cloudtasks.tasks.create.

    Nell'esempio, questo è il service account predefinito App Engine

gcloud projects add-iam-policy-binding $PROJECT_ID \
  --member=serviceAccount:${PROJECT_ID}@appspot.gserviceaccount.com \
  --role=roles/cloudtasks.enqueuer
  • L'identità utilizzata per accodare le attività a Cloud Tasks deve disporre dell'autorizzazione per utilizzare il service account associato a un'attività in Cloud Tasks.

    Nell'esempio, questo è il service account predefinito App Engine.

Consulta la documentazione di Google Cloud IAM per istruzioni su come aggiungere l'account di servizio predefinito App Engine come utente dell'account di servizio predefinito App Engine.

  • L'identità utilizzata per attivare la funzione di coda delle attività richiede l'autorizzazione cloudfunctions.functions.invoke.

    Nell'esempio, questo è il service account predefinito App Engine

gcloud functions add-iam-policy-binding $FUNCTION_NAME \
  --region=us-central1 \
  --member=serviceAccount:${PROJECT_ID}@appspot.gserviceaccount.com \
  --role=roles/cloudfunctions.invoker