Puoi eseguire flussi di lavoro di breve durata eseguendoli come Attività. Eseguire Tasks spiega come eseguire Tasks in App.
Puoi anche pianificare l'esecuzione di Tasks a intervalli ricorrenti specificati utilizzando il formato unix-cron. Con le attività pianificate, innanzitutto invii un'app che esegue l'attività come faresti con un'attività non pianificata, quindi crei un job per pianificare l'attività.
Puoi definire una pianificazione in modo che l'attività venga eseguita più volte al giorno o in giorni e mesi specifici.
Inviare un'app per l'esecuzione di attività pianificate
Clona il repository test-app.
git clone https://github.com/cloudfoundry-samples/test-app test-app
cd test-app
Esegui il push dell'app.
Esegui il push dell'app con il comando
kf push APP_NAME --task
. Il flag--task
indica che l'app è destinata all'esecuzione di attività, pertanto non verranno creati percorsi nell'app e non verrà implementata come applicazione a lungo termine.kf push test-app --task
Verifica che non siano state create istanze o route dell'app elencando l'app.
kf apps
Tieni presente che l'app non è avviata e non ha URL.
Listing Apps in Space: test-space Name Instances Memory Disk CPU URLs test-app stopped 1Gi 1Gi 100m <nil>
Crea un job
Per eseguire un'attività secondo una pianificazione, devi prima creare un job che la descriva.
kf create-job test-app test-job "printenv"
Il job si avvia in stato di sospensione o non pianificato e non crea attività finché non viene eseguito manualmente da kf run-job
o pianificato da kf schedule-task
.
Esecuzione manuale
I job possono essere eseguiti in modo ad hoc, in modo simile all'esecuzione di Tasks da kf run-task
. Questa opzione può essere utile per testare il job prima della pianificazione o per eseguirlo in base alle esigenze, oltre alla pianificazione.
kf run-job test-job
Questo comando esegue immediatamente l'attività definita dal job una sola volta.
Pianificazione di un job
Per pianificare l'esecuzione del job, devi fornire una pianificazione cron Unix nel comando kf schedule-job
.
kf schedule-job test-job "* * * * *"
Questo comando attiva il job per creare automaticamente le attività in base alla pianificazione specificata. In questo esempio, un'attività viene eseguita ogni minuto.
Puoi aggiornare la pianificazione di un job eseguendo kf schedule-task
con una nuova pianificazione.
I job in Kf possono avere una sola pianificazione cron. Questo è diverso dall'Scheduler PCF che consente più pianificazioni per un singolo job.
Se hai bisogno di più pianificazioni cron, puoi farlo con più job.
Gestione di job e pianificazioni
Visualizza tutti i job, sia pianificati che non pianificati, nello spazio corrente utilizzando il comando kf jobs
.
$ kf jobs
Listing Jobs in Space: test space
Name Schedule Suspend LastSchedule Age Ready Reason
test-job * * * * * <nil> 16s 2m True <nil>
unscheduled-job 0 0 30 2 * true 16s 2m True <nil>
Inoltre, puoi visualizzare solo i job pianificati attivamente con il comando kf job-schedules
.
$ kf job-schedules
Listing job schedules in Space: test space
Name Schedule Suspend LastSchedule Age Ready Reason
test-job * * * * * <nil> 16s 2m True <nil>
Nota che unscheduled-job
non è elencato nell'output di kf job-schedules
.
Annullamento della pianificazione di un job
Puoi interrompere un job pianificato con il comando kf delete-job-schedule
.
kf delete-job-schedule test-job
Questo comando sospende il job e ne impedisce la creazione di attività secondo la pianificazione precedente.
Il job non viene eliminato e può essere pianificato di nuovo da kf schedule-job
per continuare l'esecuzione.
Eliminare un job
L'intero job può essere eliminato con il comando kf delete-job
.
kf delete-job test-job
Questo comando elimina il job e tutte le attività create dal job, sia le esecuzioni pianificate sia quelle manuali. Se sono ancora in esecuzione attività, questo comando le elimina forzatamente.
Se vuoi assicurarti che le attività in esecuzione non vengano interrotte, elimina prima la pianificazione dei job con kf delete-job-schedule
, attendi il completamento di tutte le attività e poi elimina il job chiamando kf delete-job
.