Vai al contenuto

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 da cron indipendentemente dal fatto che anacron 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:

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