Accodare le funzioni con Cloud Tasks (1ª gen.)

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

Ad esempio, supponiamo che tu voglia creare backup di un insieme di file di immagini di grandi dimensioni attualmente ospitati su un'API con un limite di frequenza. Per essere un consumatore responsabile di questa API, devi rispettare i limiti di frequenza. Inoltre, questo tipo di job a lunga esecuzione potrebbe essere vulnerabile a errori dovuti a timeout e limiti di memoria.

Per ridurre questa complessità, puoi scrivere una funzione della coda di attività che imposta le opzioni di base delle attività, come scheduleTime e dispatchDeadline, e poi passa la funzione a una coda in Cloud Tasks. L'Cloud Tasks ambiente è progettato appositamente per garantire un controllo efficace della congestione e norme di nuovi tentativi per questo tipo di operazioni.

L'SDK Firebase per Cloud Functions for Firebase v3.20.1 e versioni successive interagisce con Firebase Admin SDK v10.2.0 e versioni successive per supportare le funzioni della coda di attività.

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

Creare funzioni della coda di attività

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

  1. Scrivi una funzione della 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 l'interfaccia a riga di comando Firebase. Quando esegui il deployment della funzione della coda di attività per la prima volta, l'interfaccia a riga di comando crea una coda di attività in Cloud Tasks con le opzioni (limitazione di 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 ed eseguendone il deployment in Cloud Functions for Firebase.

Scrivere funzioni della coda di attività

Utilizza onDispatch per iniziare a scrivere le funzioni della coda di attività. Una parte importante della scrittura di una funzione della coda di attività è l'impostazione della configurazione dei nuovi tentativi e della limitazione della frequenza per ogni 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 di Astronomy Picture of the Day della NASA:

Configurare 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 di attività viene ritentata automaticamente fino a 5 volte. In questo modo è possibile 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 ritentata almeno 60 secondi dopo ogni tentativo. In questo modo viene fornito un buffer di grandi dimensioni tra ogni tentativo, in modo da non esaurire troppo rapidamente i 5 tentativi.
  • rateLimits.maxConcurrentDispatch=6: al massimo vengono inviate 6 attività alla volta. In questo modo si garantisce un flusso costante di richieste alla funzione sottostante e si riduce il numero di istanze attive e di avvii a freddo.

Testare le funzioni della coda di attività

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

Inoltre, le funzioni della coda di attività vengono esposte come semplici funzioni HTTP nel 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

Eseguire il deployment delle funzioni della coda di attività

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

$ firebase deploy --only functions:backupApod

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

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

Accodare le funzioni della coda di attività

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

In un flusso tipico, il Admin SDK crea una nuova attività, la accoda in Cloud Tasks e imposta la configurazione dell'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 di esempio tenta di distribuire l'esecuzione delle attività associando un ritardo di N minuti per l'attività N. 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à in un momento specifico.
  • dispatchDeadlineSeconds: quantità massima di tempo Cloud Tasks attenderà il completamento di un'attività. Cloud Tasks ritenterà l'attività seguendo la configurazione dei nuovi tentativi della coda o fino al raggiungimento di questa scadenza. Nell'esempio, la coda è configurata per ritentare 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 di Cloud Tasks

I log da 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 essere generati potenzialmente nel tuo progetto. Ti consigliamo di attivare i log di debug durante lo sviluppo e il debug attivi delle funzioni della coda di attività. Consulta Attivare la registrazione.

Autorizzazioni IAM

Potresti visualizzare errori PERMISSION DENIED quando accodi le attività o quando Cloud Tasks tenta di richiamare le funzioni della coda di attività. Assicurati che il tuo progetto abbia i seguenti binding IAM:

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

    Nell'esempio, questo è l'account di servizio App Engine predefinito

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 avere l'autorizzazione per utilizzare il service account associato a un'attività in Cloud Tasks.

    Nell'esempio, questo è l'account di servizio predefinito App Engine.

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

  • L'identità utilizzata per attivare la funzione della coda di attività deve avere l'autorizzazione cloudfunctions.functions.invoke.

    Nell'esempio, questo è l'account di servizio App Engine predefinito

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