Automazione dei processi con cron
e crontab
¶
Prerequisiti¶
- Un computer con Rocky Linux in esecuzione
- Una certa dimestichezza nel modificare i file di configurazione dalla riga di comando utilizzando il proprio editor preferito (utilizzando
vi
qui)
Presupposti¶
- Conoscenza di base di bash, python o altri strumenti di scripting o programmazione, e si desidera che uno script venga eseguito automaticamente
- Che si stia operando come utente root o che si abbia la possibilità di
sudo -s
(È possibile eseguire alcuni script nelle proprie directory come proprio utente. In questo caso, il passaggio a root non è necessario)
Introduzione¶
Linux fornisce il sistema cron, un job scheduler basato sul tempo, per automatizzare i processi. È semplicistico e tuttavia molto potente. Vuoi uno script o un programma da eseguire ogni giorno alle 5 del pomeriggio? Qui è dove lo imposti.
La crontab è essenzialmente un elenco in cui gli utenti aggiungono le proprie attività e i propri lavori automatizzati, con molte opzioni che possono semplificare ulteriormente le cose. Questo documento ne esplorerà alcuni. È un buon ripasso per chi ha un po' di esperienza e i nuovi utenti possono aggiungere il sistema cron
alla loro dotazione di strumenti.
anacron
è discusso brevemente qui in riferimento alle directory cron
"dot". cron
viene eseguito da anacron
ed è utile per le macchine che non sono sempre attive, come le workstation e i notebook. Il motivo è che mentre cron
esegue i lavori in base a una pianificazione, se la macchina è spenta all'ora prevista, il lavoro non verrà eseguito. Con anacron
il lavoro verrà eseguito quando la macchina è di nuovo accesa, anche se l'esecuzione programmata è avvenuta in passato. anacron
, tuttavia, utilizza un approccio più randomizzato per eseguire compiti in cui la tempistica non è esatta. Questo ha senso per le workstation e i notebook, ma non per i server. Questo può essere un problema per cose come i backup dei server, ad esempio, che richiedono l'esecuzione di un lavoro a un'ora specifica. È qui che cron
fornisce la soluzione migliore per gli amministratori di server. Tuttavia, gli amministratori di server e gli utenti di workstation o notebook possono trarre vantaggio da entrambi gli approcci. È possibile combinarli in base alle proprie esigenze. Per ulteriori informazioni su anacron
, vedere anacron - Automazione dei comandi.
Iniziare in modo semplice: le directory dot di cron
¶
Incorporate in ogni sistema Linux da molte versioni, le directory cron
"dot" aiutano ad automatizzare i processi rapidamente. Queste appaiono come directory che il sistema cron
chiama in base alle loro convenzioni di denominazione. Questi vengono eseguiti in modo diverso, tuttavia, in base al processo assegnato per richiamarli, anacron
o cron
. Il comportamento predefinito prevede l'uso di anacron
, ma può essere modificato dall'amministratore del server, della workstation o del notebook.
Per i Server¶
Come detto nell'introduzione, cron
normalmente esegue anacron
attualmente per eseguire gli script in queste directory "dot". È possibile che si vogliano usare queste directory "dot" anche sui server e, in tal caso, è necessario eseguire due passaggi per verificare che queste directory "dot" vengano eseguite secondo un sistema di pianificazione rigoroso. Per farlo, è necessario installare un pacchetto e rimuoverne un altro:
dnf install cronie-noanacron
e
dnf remove cronie-anacron
Come ci si potrebbe aspettare, questo rimuove anacron
dal server e torna ad eseguire i compiti all'interno delle directory "dot" con una pianificazione rigorosa. /etc/cron.d/dailyjobs
è il file che controlla la pianificazione, con i seguenti contenuti:
# Run the daily, weekly, and monthly jobs if cronie-anacron is not installed
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
# run-parts
02 4 * * * root [ ! -f /etc/cron.hourly/0anacron ] && run-parts /etc/cron.daily
22 4 * * 0 root [ ! -f /etc/cron.hourly/0anacron ] && run-parts /etc/cron.weekly
42 4 1 * * root [ ! -f /etc/cron.hourly/0anacron ] && run-parts /etc/cron.monthly
Questo si traduce in quanto segue:
- eseguire gli script in
cron.daily
alle 04:02:00 ogni giorno. - eseguire gli script in
cron.weekly
alle 04:22:00 di domenica ogni settimana. - eseguire gli script in
cron.monthly
alle 04:42:00 il primo giorno di ogni mese.
Per le workstations¶
Se si desidera eseguire gli script su una workstation o un notebook nelle directory cron
"dot", non è necessario eseguire nulla di complicato. Copiate il file di script nella directory in questione e assicuratevi che sia eseguibile. Ecco le directory:
/etc/cron.hourly
- Gli script inseriti qui verranno eseguiti un minuto dopo l'ora ogni ora (eseguiti dacron
indipendentemente dal fatto cheanacron
sia installato o meno)/etc/cron.daily
- Gli script messi qui saranno eseguiti ogni giorno.anacron
regola la tempistica di queste operazioni (vedere il suggerimento)/etc/cron.weekly
- Gli script inseriti qui verranno eseguiti ogni 7 giorni, in base al giorno del calendario dell'ultima esecuzione (vedi suggerimento)/etc/cron.monthly
- Gli script inseriti qui verranno eseguiti mensilmente in base al giorno di calendario dell'ultima esecuzione (vedi suggerimento)
Suggerimento
È probabile che questi vengano eseguiti ad orari simili (ma non esattamente gli stessi) ogni giorno, settimana e mese. Per tempi di esecuzione più precisi, vedi le @opzioni qui sotto.
Se si è in grado di lasciare che il sistema esegua automaticamente gli script e che questi vengano eseguiti in un momento specifico, questo semplifica l'automazione delle attività.
Nota
Non c'è nessuna regola che dice che un amministratore del server non può usare i tempi di esecuzione randomizzati che anacron
usa per eseguire gli script nelle directory "dot". Il caso d'uso per questo sarebbe per uno script che non è sensibile al tempo.
Creare il proprio cron
¶
Se gli orari automatici e casuali non funzionano bene per le postazioni di lavoro o gli orari programmati per i server, è possibile crearne di propri. In questo esempio, si presume che l'operazione venga eseguita come utente root. Per farlo, digitare quanto segue:
crontab -e
In questo modo si recupera il crontab
dell'utente root, così come si trova in questo momento, nell'editor scelto, e potrebbe avere un aspetto simile a questo. Leggete questa versione commentata, poiché contiene le descrizioni di ogni campo che utilizzerete successivamente:
# Edit this file to introduce tasks to be run by cron.
#
# Each task to run has to be defined through a single line
# indicating with different fields when the task will be run
# and what command to run for the task
#
# To define the time you can provide concrete values for
# minute (m), hour (h), day of month (dom), month (mon),
# and day of week (dow) or use '*' in these fields (for 'any').
#
# Notice that tasks will be started based on the cron's system
# daemon's notion of time and timezones.
#
# Output of the crontab jobs (including errors) is sent through
# email to the user the crontab file belongs to (unless redirected).
# cron
# For example, you can run a backup of all your user accounts
# at 5 a.m every week with:
# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
#
# For more information see the manual pages of crontab(5) and cron(8)
#
# m h dom mon dow command
Notate che questo particolare file crontab
ha un po' della sua documentazione incorporata. Non è sempre così. Quando si modifica un crontab
su un container o su un sistema operativo minimalista, il crontab
sarà un file vuoto a meno che non ci sia una voce al suo interno.
Si supponga di avere uno script di backup da eseguire alle 22: 00 di sera. Il crontab
utilizza un orologio di 24 ore, quindi le 22:00. Si ipotizza che lo script di backup sia “backup” e che si trovi attualmente nella directory /usr/local/sbin.
Nota
Ricorda che anche questo script deve essere eseguibile (chmod +x
) affinché il cron
lo esegua.
Per elencare gli attuali lavori in esecuzione
crontab -l
Per elencare tutti i lavori creati dall'utente
crontab -l -u <username>
Per aggiungere il lavoro, eseguire:
crontab -e
crontab
è l'acronimo di "cron table" e il formato del file è, di fatto, un layout di tabella libera. Ora che siete nel crontab
, andate in fondo al file e aggiungete la vostra voce. Se si utilizza vi
come editor di sistema predefinito, lo si farà con i seguenti tasti:
Shift+:+$
Ora che siete in fondo al file, inserite una riga e un breve commento per descrivere la vostra voce. A questo scopo si aggiunge un "#" all'inizio della riga:
# Backing up the system every night at 10PM
Premere Enter. Dovreste essere ancora nella modalità di inserimento, quindi il passo successivo è aggiungere la voce. Come mostrato nella nostra crontab
vuota e commentata (sopra), questo è m per minuti, h per ore, dom per giorno della settimana, mon per mese, e dow giorno della settimana.
Per eseguire il nostro script di backup ogni giorno alle 10:00, la voce si presenta così:
00 22 * * * /usr/local/sbin/backup
Questo dice di eseguire lo script alle 22:00, ogni giorno del mese, ogni mese e ogni giorno della settimana. Questo è un esempio molto semplice e le cose possono complicarsi quando si ha bisogno di informazioni specifiche.
Le @options per crontab
¶
Un altro modo per eseguire i lavori a un orario strettamente programmato (ad esempio, giorno, settimana, mese, anno e così via) è quello di utilizzare le opzioni @, che offrono la possibilità di utilizzare una tempistica più naturale. Le @options sono costituite da:
@hourly
esegue lo script ogni ora di ogni giorno a 0 minuti dopo l'ora (questo è esattamente il risultato del posizionamento dello script in/etc/cron.hourly
).@daily
esegue lo script ogni giorno a mezzanotte.@weekly
esegue lo script ogni settimana a mezzanotte di domenica.@monthly
esegue lo script ogni mese a mezzanotte del primo giorno del mese.@yearly
esegue lo script ogni anno alla mezzanotte del primo giorno di gennaio.@reboot
esegue lo script solo all'avvio del sistema.
Nota
L'uso di queste voci di crontab
bypassa il sistema anacron
e ritorna al crond.service
sia che anacron
sia installato o meno.
Per il nostro esempio di script di backup, se si usa l'opzione @daily per eseguire lo script di backup a mezzanotte, la voce avrà il seguente aspetto:
@daily /usr/local/sbin/backup
Opzioni più complesse¶
Finora le soluzioni utilizzate sono state piuttosto semplicistiche, ma che dire di tempistiche più complesse? Supponiamo di voler eseguire lo script di backup ogni 10 minuti durante il giorno (probabilmente non è una cosa pratica da fare, ma è un esempio!). Per fare questo il crontab è:
*/10 * * * * /usr/local/sbin/backup
E se si volesse eseguire il backup ogni 10 minuti, ma solo il lunedì, il mercoledì e il venerdì?:
*/10 * * * 1,3,5 /usr/local/sbin/backup
Che ne dite di una frequenza di 10 minuti ogni giorno, tranne il sabato e la domenica?:
*/10 * * * 1-5 /usr/local/sbin/backup
Nella tabella, le virgole consentono di specificare singole voci all'interno di un campo, mentre il trattino consente di specificare un intervallo di valori all'interno di un campo. Questo è vero per qualsiasi campo e può essere vero per molti campi allo stesso tempo. Come si può vedere, le cose possono diventare piuttosto complicate.
Per determinare quando eseguire uno script, è necessario prendersi del tempo e pianificarlo, soprattutto se i criteri sono complessi.
Conclusioni¶
Il sistema cron/crontab è un potente strumento per l'amministratore di sistemi Rocky Linux o per l'utente desktop. Permette di automatizzare le attività e gli script in modo da non doversi ricordare di eseguirli manualmente. Esempi più complessi sono riportati qui:
- Per le macchine che non sono attive 24 ore al giorno, esplorate anacron - Automazione dei comandi.
- Per una descrizione concisa dei processi
cron
, controlla cronie - Attività a tempo
Mentre le basi sono piuttosto semplici, le opzioni possono essere più complesse. Per maggiori informazioni su crontab
vai alla pagina del manuale di crontab. Sulla maggior parte dei sistemi, è anche possibile digitare man crontab
per ulteriori dettagli sui comandi. Potete anche fare una ricerca sul web per "crontab", che vi darà una grande quantità di risultati per aiutarvi a perfezionare le vostre capacità nell'uso di crontab
.
Author: Steven Spencer
Contributors: Ezequiel Bruni, Ganna Zhyrnova