I cron job vengono pianificati a intervalli ricorrenti, specificati utilizzando un formato basato attivo unix-cron. Puoi definire una pianificazione in modo che il job venga eseguito più volte al giorno oppure in giorni e mesi specifici. Anche se non consigliamo più di utilizzarla, la precedente sintassi cron di App Engine è ancora supportata per i job esistenti.
Formato del cron job
Puoi utilizzare la console Google Cloud, Google Cloud CLI o l'API REST di Cloud Scheduler per impostare la tua programmazione.
Una pianificazione viene definita utilizzando il formato di stringa unix-cron (* * * * *
), che è un insieme di cinque campi in una riga che indica quando deve essere eseguito il job.
I campi temporali hanno i seguenti formati e valori possibili e devono rispettare questo ordine:
|------------------------------- Minute (0-59) | |------------------------- Hour (0-23) | | |------------------- Day of the month (1-31) | | | |------------- Month (1-12; or JAN to DEC) | | | | |------- Day of the week (0-6; or SUN to SAT; or 7 for Sunday) | | | | | | | | | | * * * * *
Campo | Formato dei valori validi |
---|---|
Minuto | 0-59 |
Ora | 0-23 |
Giorno del mese | 1-31 |
Mese | 1-12 (o da JAN a DEC) |
Giorno della settimana | 0-6 (o da SUN a SAT; o 7 per la domenica) |
Minuti: indica quanto tempo è trascorso dall'inizio dell'ora in cui viene eseguito il job, in minuti. Ad esempio, se il minuto è impostato su
0
, il job viene eseguito parte superiore dell'ora (perché è 0 minuti dopo l'ora). Pertanto, se l'ora è 08:00, il job viene eseguito alle 08:00.Ora: indica il numero di ore dopo la mezzanotte in cui viene eseguito il job (arrotondato per difetto all'ora più vicina, perché i minuti rimanenti sono indicati nel campo
minute
). La mezzanotte è0
e mezzogiorno è12
. Ad esempio, se l'ora è impostata su0
, il job viene eseguito nell'ora di mezzanotte (poiché è 0 ore dopo mezzanotte).Giorno del mese: indica la data di calendario del mese. Ad esempio,
1
per il primo giorno del mese. Cloud Scheduler non supportaL
come ultimo giorno del mese.Mese: indica il mese. Specifica il numero del mese o le prime tre lettere del nome del mese in maiuscolo. Ad esempio,
1
per gennaio o, in modo equivalente,JAN
.Giorno della settimana: indica il giorno della settimana. Lunedì è
1
, martedì è2
e così via.0
o7
può indicare domenica. Specifica il giorno della settimana tramite numero o tramite le prime tre lettere del nome del giorno della settimana in maiuscolo (ad esempioSUN
per domenica).- Questo campo viene valutato come
OR
inclusivo con il campoday of the month
, a meno che uno di questi campi non sia contrassegnato come senza restrizioni dall'asterisco (*
). Ad esempio, se il giorno del mese è impostato su1
e il giorno della settimana è impostato suSAT
, il job viene eseguito il primo giorno del mese e ogni sabato del mese, anche se il primo giorno del mese non è un sabato. Se il giorno della settimana non è soggetto a limitazioni (imposta a*
), il job viene eseguito solo il primo giorno del mese.
- Questo campo viene valutato come
Corrispondenza a tutti i valori
Per trovare tutte le corrispondenze per un campo, utilizza l'asterisco: *
. Se un campo è impostato su
l'asterisco, il campo corrisponde a tutti i valori validi per quel campo ogni volta che
siano soddisfatte le altre condizioni dei campi. L'impostazione di un campo sull'asterisco è
a volte equivale a lasciare il campo unrestricted (senza restrizioni), perché non è
limitati a un valore specifico.
Ecco due esempi in cui il campo dei minuti non viene limitato:
* 0 1 1 1
: il job viene eseguito ogni minuto dell'ora di mezzanotte del 1° gennaio e dei lunedì.* * * * *
: il job viene eseguito ogni minuto (di ogni ora, di ogni giorno del mese, di ogni mese, di ogni giorno della settimana, perché anche ciascuno di questi campi è senza restrizioni).
L'asterisco equivale a un caso speciale di un intervallo, in cui
inizia al primo valore valido per il campo e termina all'ultimo valore valido
valore del campo (ad esempio, 0-59
per il campo dei minuti).
Corrispondenza a un intervallo
Per trovare una corrispondenza con un intervallo di valori, specifica i valori di inizio e fine, separati da un
Trattino (-
). Non includere spazi nell'intervallo. Gli intervalli sono inclusi. La
il primo numero deve essere inferiore al secondo. Se utilizzi abbreviazione
nomi del mese o del giorno della settimana (ad es. JAN
anziché 1
per il primo
mese dell'anno), il primo valore deve essere antecedente al mese o alla settimana rispetto
il secondo valore.
I seguenti esempi equivalenti vengono eseguiti a mezzanotte di lunedì, martedì Mercoledì, giovedì e venerdì (per tutti i mesi):
0 0 * * 1-5
0 0 * * MON-FRI
Corrispondenza di un elenco
Gli elenchi possono contenere qualsiasi valore valido per il campo, inclusi gli intervalli.
Specifica i valori separati da una virgola (,
). Non includere spazi nell'elenco.
Esempi:
0 0,12 * * *
: il job viene eseguito a mezzanotte e a mezzogiorno.0-5,30-35 * * * *
: il job viene eseguito in ciascuno dei primi cinque minuti di ogni mezz'ora (all'inizio e alla metà dell'ora).
Saltare i valori in un intervallo
Puoi saltare i valori in un intervallo specificando una frequenza con cui esaminare l'intervallo. Questo sistema a volte è indicato come l'utilizzo di una funzione step (o
value o un'espressione tariffaria). Per farlo, specifica l'intervallo, seguito dal
barra obliqua (/
) e la frequenza con cui vuoi saltare l'intervallo.
Puoi utilizzare l'asterisco (*
) per indicare l'intervallo di tutti i valori per il
campo. Quando utilizzi l'asterisco, il primo valore dell'intervallo è 0 per i campi minuto,
ora e giorno della settimana (domenica) e 1 per i campi giorno del mese e mese.
Il valore del passaggio non può essere superiore al valore massimo possibile per il campo.
Il passaggio predefinito è 1, quindi la funzione step /1
è la stessa che non utilizzare una funzione step.
Esempi di intervalli che utilizzano funzioni a gradino:
*/2
: questa è una funzione di passo valida per qualsiasi campo. Per il campo dei minuti, corrisponde a 0, 2, 4, ... , 58. Per l'ora, corrisponde a 0, 2, 4, ... , 22. Per il giorno del mese, corrisponde a 1, 3, 5, ..., 31 (per un mese di 31 giorni). Per il mese, corrisponde a 1, 3, 5, ... , 11. Per il giorno della settimana, corrisponde a 0, 2, 4, 6.0-12/2
: questa è una funzione di passaggio valida per i campi dei minuti e delle ore. it corrisponde a 0, 2, 4, ... , 12.
Esempi di programmazioni che utilizzano le funzioni di passaggio:
*/2 * * * *
: il job viene eseguito ogni due minuti.0 0-12/2 * * *
: il job viene eseguito ogni due ore, a ora in punto. La prima esecuzione è a mezzanotte. L'ultima esecuzione è a mezzogiorno.
Pianificazioni di esempio
La tabella seguente mostra alcuni esempi di pianificazioni cron job e la relativa descrizione:
Pianificazione | Formato cron job | Spiegazione |
---|---|---|
Ogni minuto | * * * * * |
Viene eseguito in base al minuto. Ad esempio, 9:00, 9:01, 9:02 e così via. |
Ogni ora | 0 * * * * |
Viene eseguita ogni ora. Ad esempio, 9:00, 10:00, 11:00 e così via. |
Ogni giorno | 0 0 * * * |
Viene eseguito alle 00:00 (00:00 nel formato 24 ore) tutti i giorni. |
Ogni giorno feriale (lun-ven) |
I seguenti valori sono equivalenti:
|
Viene eseguito alle 00:00 (formato 24 ore) di lunedì, martedì, mercoledì, giovedì e venerdì. |
Ogni settimana | I seguenti valori sono equivalenti:
|
Viene eseguita la domenica alle 00:00 (formato 24 ore). |
Ogni mese | 0 0 1 * * |
Viene eseguito alle 00:00 (formato 24 ore) del primo giorno del mese. |
Ogni trimestre | I seguenti valori sono equivalenti:
|
Viene eseguito alle ore 00:00 (00:00 nel formato 24 ore) del primo giorno del trimestre, per una pianificazione trimestrale standard: 1° gennaio, 1° aprile, 1° luglio e 1° ottobre. |
Ogni anno | I seguenti valori sono equivalenti:
|
Viene eseguito alle 00:00 (00:00 nel formato 24 ore) del primo giorno del primo mese dell'anno (1° gennaio). |
Fuso orario
Puoi selezionare il fuso orario per la valutazione della pianificazione nella console Google Cloud (nella pagina Crea un job, seleziona un Fuso orario dall'elenco) o tramite il flag gcloud
--time-zone
quando crei il job.
Il valore di questo campo deve essere l'abbreviazione del fuso orario utilizzata nel
database tz.
Il fuso orario predefinito è UTC
.
Per alcuni fusi orari, l'ora legale può causare l'esecuzione o la mancata esecuzione dei job in modo imprevisto. Questo accade perché Cloud Scheduler viene eseguito in base al tempo reale. Nei casi in cui un orario può verificarsi due volte (ad esempio quando gli orologi vanno indietro) e il job è pianificato in questo momento, il job pianificato potrebbe registrare anomalie di esecuzione.
Se il tuo job richiede una cadenza molto specifica, ti consigliamo di scegliere un fuso orario che non osservi l'ora legale. Nello specifico, per evitare completamente il problema, è consigliabile utilizzare il fuso orario UTC per Cloud Scheduler.