In questa pagina viene descritto come creare e personalizzare una coda in modalità push e come per esaminare i contenuti di una coda.
Utilizzo di un file di configurazione delle code per creare code
Per elaborare un'attività, devi aggiungerla a una coda in modalità push. App Engine fornisce
coda in modalità push predefinita, denominata default
, che è configurata e
pronto per l'uso con le impostazioni predefinite. Se vuoi, puoi semplicemente aggiungere tutte le tue attività
alla coda predefinita, senza dover creare e configurare altre code.
Per aggiungere code o modificare la configurazione predefinita, modifica il file di configurazione della coda per la tua applicazione, che carichi su App Engine. Puoi creare fino a 100 code. Le code non possono essere create dinamicamente.
Questo file di configurazione della coda definisce due code:
queue:
- name: queue-blue
target: v2.task-module
rate: 5/s
- name: queue-red
rate: 1/s
Per caricare il file:
gcloud app deploy queue.yaml
Tutte le attività aggiunte a queue-blue
vengono inviate al modulo di destinazione v2.task-module
.
La frequenza di aggiornamento di queue-red
è passata da 5/s a 1/s. Le attività saranno
sono stati rimossi in coda e inviati ai rispettivi obiettivi alla velocità di 1 attività al secondo.
Se elimini una coda, devi attendere circa 7 giorni prima di crearne una nuova con lo stesso nome.
Esistono molti altri parametri che possono essere aggiunti al file di configurazione per personalizzare il comportamento di una coda push. Per ulteriori informazioni, consulta riferimento al file di configurazione della coda.
Definizione della frequenza di elaborazione della coda push
Puoi controllare la frequenza con cui le attività vengono elaborate in ciascuna delle tue code
la definizione di altre direttive, come
rate
,
bucket_size
,
e
max_concurrent_requests
La coda delle attività utilizza i bucket di token per controllare la frequenza di esecuzione delle attività. Ogni coda denominata ha un token bucket
contiene token fino al limite massimo specificato da bucket_size
o a un massimo di
5 token se non specifichi la dimensione del bucket.
Ogni volta che l'applicazione esegue un'attività, un token viene rimosso dal bucket.
La tua app continua a elaborare le attività in coda fino all'esecuzione del bucket della coda
di token. App Engine rifornisce continuamente il bucket con nuovi token in base al rate
specificato per la coda.
Se la coda contiene attività da elaborare e il bucket della coda contiene token, App Engine elabora contemporaneamente tante attività quanti sono i token. Ciò può comportare picchi di elaborazione, consumare risorse di sistema e competere con le richieste di pubblicazione per gli utenti.
Se vuoi evitare l'esecuzione di troppe attività contemporaneamente o la contesa del data store, utilizza max_concurrent_requests
.
L'esempio seguente mostra come impostare max_concurrent_requests
per limitare le attività e come regolare la dimensione e la frequenza del bucket in base alle esigenze e alle risorse disponibili dell'applicazione:
queue:
- name: queue-blue
rate: 20/s
bucket_size: 40
max_concurrent_requests: 10
Impostazione dei limiti di spazio di archiviazione per tutte le code
Puoi utilizzare il file di configurazione della coda per definire la quantità totale di spazio di archiviazione che i dati delle attività possono consumare in tutte le code. Per definire il limite di spazio di archiviazione totale, includi un elemento denominato total_storage_limit
al livello superiore:
# Set the total storage limit for all queues to 120MB
total_storage_limit: 120M
queue:
- name: queue-blue
rate: 35/s
Il valore è un numero seguito da un'unità: B
per byte, K
per kilobyte, M
per megabyte, G
per gigabyte, T
per terabyte. Ad esempio, 100K
specifica un limite di 100 kilobyte. Se l'aggiunta di un'attività
fa sì che la coda
se superi il limite di spazio di archiviazione, la chiamata per aggiungere l'attività non andrà a buon fine. Il limite predefinito è 500M
(500 megabyte) per le app gratuite. Per le app fatturate non esiste alcun limite finché non ne imposti uno esplicitamente. Puoi utilizzare questo limite per proteggere la tua app da un fork
bomba
errore di programmazione in cui ogni attività aggiunge più altre attività durante
dell'esecuzione.
Se la tua app riceve errori relativi a una quota insufficiente durante l'aggiunta di attività, può essere utile aumentare il limite di spazio di archiviazione totale. Se utilizzi questo di archiviazione, consigliamo vivamente di impostare un limite che corrisponda al tempo di archiviazione per diversi giorni diverse attività. In questo modo è possibile eseguire il backup temporaneo delle code e continuare ad accettare nuove attività mentre si lavora alla coda, rimanendo al contempo protetti da un errore di programmazione della bomba fork.
Monitoraggio delle code nella console Google Cloud
Nella console Google Cloud, vai alla pagina Cloud Tasks.
Tieni presente che se vai alla pagina Coda di lavoro di App Engine, troverai istruzioni che ti guideranno alla pagina Cloud Tasks. Questo aggiornamento nella console Google Cloud non modifica il modo in cui le code delle attività personalizzata.
Abilita l'API Cloud Tasks.
Nella pagina Cloud Tasks vedrai un elenco di tutte delle code nell'applicazione. Se fai clic sul nome di una coda, viene visualizzata la pagina Dettagli coda, che mostra tutte le attività nella coda selezionata.
Passaggi successivi
Scopri di più sulla creazione di attività.