Funzioni di pianificazione

Se desideri pianificare le funzioni da eseguire a orari specificati, usa functions.pubsub.schedule().onRun() Questo metodo pratico crea un argomento Pub/Sub e utilizza Cloud Scheduler per attivare eventi su quell'argomento, assicurando che la tua funzione venga eseguita su il programma desiderato.

Prima di iniziare

Per utilizzare questa soluzione nel tuo progetto Firebase, il tuo progetto deve essere nel piano tariffario Blaze. Se non è già incluso nel piano Blaze, aggiorna il piano tariffario .

Sebbene sia richiesta la fatturazione, puoi aspettarti che il costo complessivo sia gestibile, poiché ogni lavoro di Cloud Scheduler costa $ 0,10 (USD) al mese e c'è una franchigia di tre lavori per account Google, gratuitamente. Utilizza il calcolatore dei prezzi di Blaze per generare una stima dei costi basata sull'utilizzo previsto.

Le API Pub/Sub e Cloud Scheduler devono essere abilitate per il tuo progetto. Questi dovrebbero essere già abilitati per la maggior parte dei progetti Firebase; puoi verificare nella console di Google Cloud Platform .

Scrivi una funzione pianificata

In Cloud Functions for Firebase, la logica di pianificazione risiede nel codice delle funzioni, senza particolari requisiti di tempo di implementazione. Per creare una funzione pianificata, usa functions.pubsub.schedule('your schedule').onRun((context)) . Ad esempio, per eseguire una funzione ogni cinque minuti con la sintassi cron.yaml di App Engine , esegui qualcosa del genere:

exports.scheduledFunction = functions.pubsub.schedule('every 5 minutes').onRun((context) => {
  console.log('This will be run every 5 minutes!');
  return null;
});

Sia la sintassi Unix Crontab che quella di App Engine sono supportate da Cloud Scheduler. Ad esempio, per utilizzare Crontab per selezionare un fuso orario specifico in cui eseguire una funzione pianificata, eseguire una procedura del genere:

exports.scheduledFunctionCrontab = functions.pubsub.schedule('5 11 * * *')
  .timeZone('America/New_York') // Users can choose timezone - default is America/Los_Angeles
  .onRun((context) => {
  console.log('This will be run every day at 11:05 AM Eastern!');
  return null;
});

Il valore per timeZone deve essere un nome di fuso orario dal database tz . Consulta il riferimento di Cloud Scheduler per ulteriori informazioni sulle proprietà supportate.

Distribuire una funzione pianificata

Quando si distribuisce una funzione pianificata, il processo di pianificazione e l'argomento pub/sub correlati vengono creati automaticamente. L'interfaccia a riga di comando di Firebase fa eco al nome dell'argomento e puoi visualizzare il lavoro e l'argomento nella console GCP . L'argomento è denominato secondo la seguente convenzione:

firebase-scheduled- function_name - region

Per esempio:

firebase-scheduled-scheduledFunctionCrontab-us-east1.