Il servizio cron di App Engine ti consente di configurare attività programmate ricorrenti eseguite in orari specifici o a intervalli regolari. Queste attività sono comunemente chiamate cron job. Questi cron job vengono attivati automaticamente dal servizio cron di App Engine. Ad esempio, puoi utilizzare un job cron per inviare un report via email ogni giorno, per aggiornare alcuni dati memorizzati nella cache ogni 10 minuti o per aggiornare le informazioni di riepilogo una volta all'ora.
Un cron job invia una richiesta HTTP GET
programmata all'endpoint specificato nella stessa app in cui è configurato il cron job. Il gestore dell'endpoint esegue la logica quando viene chiamato.
Il servizio Cron di App Engine non può essere utilizzato per chiamare endpoint web esterni all'app host di App Engine. Non può essere utilizzato per chiamare endpoint di App Engine da altre app oltre all'app host.
Una richiesta di job cron è soggetta agli stessi limiti previsti per le code di attività push.
Prima di iniziare
Per eseguire il deployment o l'aggiornamento delle pianificazioni, il tuo account richiede uno dei seguenti ruoli IAM:
- Proprietario
- Editor
Puoi impostare l'autorizzazione nella pagina IAM della console .
Creazione di un cron job
- Crea il file
cron.yaml
nella directory principale della tua applicazione (insieme aapp.yaml
). Aggiungi una o più voci
<cron>
al file e definisci gli elementi necessari per il job, inclusi gli elementi<url>
e<schedule>
obbligatori. Esamina la sintassi e le opzioni di cron.yaml per ulteriori dettagli sugli elementi del filecron.yaml
.L'esempio seguente crea un cron job di base che viene eseguito ogni giorno:
cron: - description: "daily summary job" url: /tasks/summary target: beta schedule: every 24 hours
La specifica target è facoltativa ed è il nome di un servizio/una versione. Se presente, il target viene anteposto al nome host dell'app, in modo che il job venga indirizzato a quel servizio/a quella versione. Se non viene specificato alcun target, il job verrà eseguito nelle versioni del
default
servizio configurate per il traffico.Crea un gestore per l'URL del cron job. L'handler deve eseguire tutte le attività che vuoi pianificare. Il gestore deve rispondere con un codice di stato HTTP tra 200 e 299 (inclusi) per indicare il successo. È possibile recuperare altri codici di stato che possono essere utilizzati per riprovare il job cron.
web.xml
deve essere uguale all'URL del job cron.
Testare i cron job nel server di sviluppo
Il server di sviluppo locale non esegue automaticamente i job cron. Puoi effettuare richieste direttamente all'URL del tuo cron job per testare la funzionalità. Puoi utilizzare l'interfaccia di cron o delle attività pianificate locale per attivare gli URL dei tuoi job con curl o uno strumento simile.
Nuovo tentativo di esecuzione dei cron job non riusciti
Se il gestore delle richieste di un job cron restituisce un codice di stato non compreso tra 200 e 299 (inclusi), App Engine considera il job non riuscito. Per impostazione predefinita, non viene eseguito alcun nuovo tentativo per i job non riusciti, a meno che non venga restituito un codice di stato 503, nel qual caso viene eseguito un nuovo tentativo ogni minuto finché non va a buon fine o non viene restituito un codice di stato compreso tra 200 e 299.
Per impostare i job non riusciti in modo che vengano riprovati:
- Includi un blocco
retry_parameters
nel filecron.yaml
. Scegli e imposta i parametri di ripetizione nel blocco
retry_parameters
.Ad esempio, questo file
cron.yaml
di esempio contiene un singolo job cron configurato per riprovare fino a cinque volte (il valore predefinito) con un intervallo di attesa iniziale di 2,5 secondi che raddoppia ogni volta.cron: - description: "retry demo" url: /retry schedule: every 10 mins retry_parameters: min_backoff_seconds: 2.5 max_doublings: 5
Scopri di più sulle opzioni di ripetizione di cron.
Eseguire il deployment dei cron job
Per eseguire il deployment dei job cron specificati nel file di configurazione cron.yaml
,
esegui il seguente comando:
gcloud
gcloud app deploy cron.yaml
Maven
mvn appengine:deployCron cron.yaml
Gradle
gradle appengineDeployCron cron.yaml
IDE
Se utilizzi IntelliJ o Eclipse, seleziona i singoli file di configurazione da eseguire il deployment utilizzando il modulo di deployment.
Eliminazione di tutti i cron job
Per eliminare tutti i cron job:
Modifica i contenuti del
cron.yaml
file in modo da:cron:
Esegui il deployment del file
cron.yaml
in App Engine.
Protezione degli URL per cron
Un gestore cron è solo un normale gestore definito in app.yaml
. Puoi impedire agli utenti di accedere agli URL utilizzati dalle attività pianificate limitando l'accesso agli account amministratore. Le attività pianificate possono accedere agli URL solo per amministratori. Puoi limitare un URL aggiungendo login: admin
alla configurazione dell'handler in app.yaml
.
Un esempio potrebbe essere il seguente in app.yaml
:
application: hello-cron
version: 1
runtime: java
api_version: 1
handlers:
- url: /report/weekly
servlet: mysite.server.CronServlet
login: admin
Per testare un job cron, accedi come amministratore e visita l'URL dell'handler nel browser.
Le richieste del servizio Cron conterranno anche un'intestazione HTTP:
X-Appengine-Cron: true
L'intestazione X-Appengine-Cron
viene impostata internamente da App Engine. Se il gestore delle richieste trova questa intestazione, può considerare attendibile che la richiesta sia una richiesta di cron. Se l'intestazione è presente in una richiesta di un utente esterno alla tua app, viene rimossa, ad eccezione delle richieste degli amministratori dell'applicazione che hanno eseguito l'accesso, che sono autorizzati a impostare l'intestazione a fini di test.
App Engine invia richieste Cron dall'indirizzo IP0.1.0.2
. Per i cron job creati con versioni precedenti di gcloud (precedente alla 326.0.0), le richieste di Cron provengono da 0.1.0.1
.
Chiamate a Google Cloud Endpoints
Non puoi specificare un endpoint Google Cloud nel
campo url
di un job cron.
Se vuoi che il tuo job cron chiami un endpoint Google Cloud,
invia una richiesta a un target servito da un gestore nella
tua app e chiama la classe e il metodo dell'endpoint dal codice del gestore.
Visualizzazione dei job cron nella console Google Cloud
Puoi visualizzare i cron job pianificati nella scheda Cron job App Engine di Cloud Scheduler.
Puoi anche visualizzare i log per vedere quando sono stati aggiunti o rimossi i job cron.
Scopri di più
Consulta le informazioni dettagliate sulla definizione dei cron job nella documentazione di riferimento di cron.yaml.