Programmation de travaux avec at cron anacron

De Lea Linux
Révision datée du 2 septembre 2005 à 18:06 par PingouinMigrateur (discussion | contributions) (conversion de la documentation originale de Léa par HTML::WikiConverter)
(diff) ← Version précédente | Voir la version actuelle (diff) | Version suivante → (diff)
Aller à la navigation Aller à la recherche

Programmation de travaux

Programmation de travaux
par Anne
Où comment rendre son pingouin autonome :)

Pourquoi ces outils de programmation ?

Imaginez que vous souhaitez lancer une tâche durant la nuit, ou bien effectuer des sauvegardes régulières de vos données, remettre à jour la base de vos packages... L'objectif de cet article est de vous présenter le fonctionnement et le paramétrage de trois outils de programmation sous Linux.

Les différents outils de programmation de tâches

Votre système dispose de plusieurs outils de programmation de tâche en fonction de ce que vous souhaitez réaliser :

  • at : permet l'exécution d'une tâche donnée à un moment donné, et ce, une seule fois. Si la machine n'est pas allumée à ce moment-là, la tâche ne sera pas exécutée. Toutefois, dès que la machine est rallumée, elle est exécutée. La commande est utilisable par root et/ou tout autre utilisateur déclaré sur la machine.
    Exemple : programmer la sauvegarde de /home le 25 décembre à 23h30.
  • cron : permet l'exécution d'une ou plusieurs tâches à des moments selon un intervalle de temps fixé et répété. Si la machine n'est pas allumée à ce moment-là, la tâche ne sera pas exécutée. La commande est utilisable par root et/ou tout autre utilisateur déclaré sur la machine.
    Exemple : programmer la sauvegarde de /home tous les jours à 23h30.
  • anacron : permet l'exécution d'une ou plusieurs tâches après une période de temps déterminée. Si la machine n'est pas allumée à ce moment-là, la tâche sera exécutée dés que possible. La commande est utilisable uniquement par root.
    Exemple : programmer la sauvegarde de /home au bout d'une période de 7 jours. Si la machine reste éteinte 9 jours, la tâche s'exécute lors du démarrage de la machine au 10e jour..

La commande at

Comme on l'a vu plus haut, at permet de programmer l'exécution d'une tâche à un moment donné.

Fonctionnement

C'est le démon atd qui est en attente sur votre machine, qui se charge d'exécuter toutes les tâches planifiées avec at. Comme tous les services, on le retrouve dans le répertoire /etc/init.d (parfois c'est un lien vers /etc/rc.d/init.d). En cas de dysfonctionnement de at, il convient de vérifier, notamment, que le démon atd est bien lancé :

root@pingu# /etc/rc.d/init.d/atd status
atd (pid 818) en cours d'exécution

Les travaux en attente d'exécution sont stockés dans la file d'attente située dans /var/spool/at.

Syntaxe

Ajouter une programmation de tâche : at. Deux façon de l'utiliser : avec une ligne de commande ou un fichier contenant un script à exécuter.

Syntaxe :

  1. commande : at HEURE
    La commande est ensuite saisie en mode interactif. Vous pouvez saisir autant de lignes que nécessaire et terminer par Ctrl+D pour obtenir le End Of Text.
    Exemple : programmer l'affichage de "coucou" à 23h sur la console 5

anne@pingu$ at 23:00
warning: commands will be executed using (in order) a) $SHELL b) login shell c) /bin/sh
at> echo coucou > /dev/pts/5<EOT>

  1. fichier : at -f fichier HEURE
    Exemple : programmer l'exécution du script /home/anne/sauve à 23h.

anne@pingu$ at -f /home/anne/sauve c23:00

Le format de HEURE est commun aux 2 notations et permet une syntaxe assez large. Ce qui est utilisable :

  • HHMM ou HH:MM
  • midnight / noon / teatime : minuit / midi / 16h (sacrés anglais ;) )
  • MMJJAA ou MM/JJ/AA ou MM.JJ.AA : attention, les jours sont à noter après le mois (logique non ? :) )
  • now + x minutes / hours / days / weeks : x minutes / heures / jours / semaines à partir de maintenant

Lister les tâches programmées au moyen de at : atq
Exemple :

root@pingu# atq
4 2002-12-11 02:10 a root
5 2002-12-11 02:15 a root
6 2002-12-11 02:20 a root

Dans ce cas de figure, on a 3 tâches programmées avec at par root. La colonne de gauche indique le numéro de job attribué à la tâche (par ordre croissant d'arrivée dans la file).

Supprimer une ou plusieurs tâches programmées en attente d'exécution : atrm n°job
Exemple :

root@pingu# atrm 6

Contrôle de l'utilisation de la commande

La commande at est accessible à root et aux utilisateurs déclarés sur la machine. Toutefois vous avez à votre disposition 2 fichiers : /etc/at.allow (pour autoriser spécifiquement des utilisateurs à utiliser at) et/ou /etc/at.deny (pour interdire spécifiquement à des utilisateurs d'utiliser at). Si aucun des 2 fichiers n'existe, seul root peut utiliser la commande. Par défaut, il existe souvent un fichier /etc/at.deny vide qui autorise ainsi l'utilisation de cette commande par tous les utilisateurs (puisque personne n'est interdit).

Exemple : je veux autoriser uniquement les utilisateurs root, pingu et anne à utiliser la commande

root@pingu# cat /etc/at.allow
root
pingu
anne

Et, je ne crée pas de fichier /etc/at.deny donc, puisqu'il n'existe pas, personne n'a le droit d'utiliser at sauf ceux qui sont autorisés par /etc/at.allow.

La commande cron

Fonctionnement de cron

Tout comme at, cron permet de programmer des travaux à exécuter, mais ceci de manière récurrente. Par exemple pour faire une sauvegarde toutes les nuits à 2h30.

Les composantes pour le fonctionnement de cron sont :

  • un démon crond : c'est lui qui se charge d'exécuter les travaux progammées à l'aide de cron. Toutes les minutes ils vérifie la présence de nouveaux fichiers de configuration (crontab). Là encore, comme les autres services, il est situé dans /etc/init.d. Le démon doit être actif pour que les tâches puissent être exécutées.

root@pingu# /etc/rc.d/init.d/crond status
crond (pid 769) en cours d'exécution

  • un fichier de configuration, la crontab : il contient les travaux programmés et la date d'exécution. Il y a une crontab par utilisateur ayant recours à cron. Ces fichiers sont situés (habituellement) dans /var/spool/cron.
  • des commandes : elles vous permettent de manipuler le contenu de la crontab (c'est à dire de l'éditer, de la vider et de la modifier).
  • un fichier de log : le fichier /var/log/cron recense toutes les tâches programmées à l'aide de cron.

Commandes et configuration de cron

crontab : le fichier de configuration de cron

Il existe une crontab par utilisateur. Seul root peut consulter chacune d'entre elles.

Syntaxe :

Le fichier doit comporter une tâche à programmer par ligne. Chaque ligne doit comporter obligatoirement 6 colonnes :

  • 1ère colonne, les minutes : de 0 à 59
  • 2ème colonne, les heures : de 0 à 23
  • 3ème colonne, le jour du mois : de 0 à 31
  • 4ème colonne, les mois : de 0 à 12
  • 5ème colonne, le jour de la semaine : de 0 à 7 (dimanche correspondant à 0 ou 7)
  • 6ème colonne, la tâche à exécuter

Exemple : pour excuter le script /root/sauve.sh tous les jours à 23h15 on mettra dans la crontab de root

15    23    *    *     *    /root/sauve.sh

Les colonnes contenant la date d'exécution peuvent contenir divers formats pour indiquer la date (pour les exemples, on utilisera la colonne des minutes de la crontab) :

  • * : toutes les valeurs de la plage de temps
    Exemple : * indique toutes les minutes
  • 2 nombres séparés par un tiret : pour indiquer un intervalle de temps
    Exemple : 0-15 indique toutes les minutes comprises entre 0 et 15
  • 2 nombres ou plus séparés par des virgules : indique une liste de valeurs
    Exemple : 0,15,30,45 indique les minutes 0, 15, 30 et 45 (c'est à dire toutes les quart d'heure).
  • combinaison de valeurs au moyen d'un pas (/) : permet par exemple de désigner toutes les valeurs paires.
    Exemple :
    • */2 indique toutes les valeurs paires,
    • 0-15/2 indique toutes les valeurs paires des minutes comprises entre 0 et 15.

Il est bien sûr possible de combiner les différentes notations pour obtenir ce dont vous aurez besoin.

les commandes

Nous avons vu la syntaxe de la crontab. Pour éditer, modifier ou visualiser le contenu d'une crontab, il vous faut utiliser la commande crontab avec les options suivantes :

  • crontab -l : permet de visualiser le contenu de la crontab (en lecture uniquement).
  • crontab -e : permet d'éditer la crontab et éventuellement de le modifier. La commande ouvre la crontab dans un éditeur (vi par défaut sinon celui définit par la variable d'environnement EDITOR)
  • crontab -r : supprime la crontab dans /var/spool/cron

Remarque : par défaut, les commandes crontab agissent sur votre crontab uniquement. (rappel : il y a autant de crontab que d'utilisateurs ayant définit des tâches à effectuer avec cron.)
Toutefois l'administrateur (root) peut utiliser une option supplémentaire : -u user. Il spécifie ainsi la crontab de l'utilisateur qu'il veut éditer, modifier ou supprimer.

Exemple : pour modifier la crontab de l'utilisateur anne

root@pingu# crontab -u anne -e

la crontab du système

Lorsque vous installez votre distribution, une crontab particulière est crée, celle du système : /etc/crontab

root@pingu# cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/

# run-parts
01 * * * * root run-parts /etc/cron.hourly
02 4 * * * root run-parts /etc/cron.daily
22 4 * * 0 root run-parts /etc/cron.weekly
42 4 1 * * root run-parts /etc/cron.monthly

Le fichier définit tout d'abord un certain nombre de variables pour l'exécution des tâches système : SHELL, PATH, MAILTO, HOME(la définition de variables est également possible dans une crontab ordinaire, mais beaucoup plus rarement utilisé.). La suite du fichier utilise ensuite la syntaxe vue ci-dessus.

L'exécution des tâches utilise un script particulier : /usr/bin/run-parts. Il s'agit d'un script bash qui exécute toutes les commandes situées dans le répertoire passé en argument. On remarquera que la temporisation utilisée pour programmer chacune de ces lignes correspond à des tâches devant s'exécuter toutes les heures, les jours, les semaines, les mois.

Exemple : la crontab système exécute tous les jours run-parts /etc/cron.daily.
Le répertoire /etc/cron.daily contient les commandes suivantes :

root@pingu# ls /etc/cron.daily
00-logwatch 0anacron makewhatis.cron slocate.cron tmpwatch
00webalizer logrotate rpm tetex.cron

Ce sont donc tous les scripts qui seront exécutés tous les jours à 4h02.

Contrôle de l'utilisation de la commande cron

Tout comme pour la commande at, la commande la commande cron est accessible à root et aux utilisateurs déclarés sur la machine. Toutefois vous avez là encore à votre disposition 2 fichiers : /etc/cron.allow et/ou /etc/cron.deny (qui fonctionne comme ceux de at). Si aucun des 2 fichiers n'existe, le comportement peut varier d'une distribution à une autre : soit root seul peut utiliser la commande, soit aucune restriction n'est appliquée.

Exemple : je veux autoriser uniquement les utilisateurs root, pingu et anne à utiliser la commande

root@pingu# cat /etc/cron.allow
root
pingu
anne

Et, je ne crée pas de fichier /etc/at.deny.

la commande anacron

Fonctionnement de anacron

Contrairement à cron, anacron ne fonctionne pas avec un démon. Il s'agit d'une commande lancée au démarrage (/usr/sbin/anacron). Elle est souvant lancée comme un service, on peut donc, dans ce cas, trouver son script de démarrage dans /etc/init.d

anacron permet l'exécution d'une tâche au bout d'une période de temps qui se serait écoulée. Contrairement à cron, la spécification de la période ne permet pas autant de précision. Toutefois on a vu qu'une tâche programmée à l'aide de cron nécessite que le démon crond soit activé. Donc si la machine est éteinte, la tâche ne sera pas exécutée.

Imaginez que vous programmiez une tâche pour qu'elle s'exécute toutes les semaines. Votre machine est éteinte durant 10 jours, la commande sera donc exécutée au prochain redémarrage.

Attention anacron est un utilitaire strictement réservé à root. Le fichier de configuration est /etc/anacrontab.

Le fichier de configuration : anacrontab

Il a une syntaxe similaire à celle de la crontab, il faut donc mette une ligne par tâche à effectuer. Chaque ligne doit contenir 4 colonnes :

  • 1ère colonne, intervalle : exprimé en jours, il indique l'intervalle de temps entre 2 exécution d'une tâche.
  • 2ème colonne, délai : exprimé en minutes, c'est le délai entre 2 tâches exécutées par anacron, pour éviter qu'elles ne s'exécutent en même temps.
  • 3ème colonne, étiquette : commentaire ajouté pour les logs de anacron
  • 4ème colonne, commande : tâche à exécuter

La ligne suivante :

1    65   cron.daily   run-parts /etc/cron.daily

signifie que la commande run-parts /etc/cron.daily sera exécutée 1 fois par jour, chaque tâche sera séparées des autres d'au moins 65 minutes.

Exemple : ci-dessous un exemple de anacrontab

root@pingu# cat /etc/anacrontab
SHELL=/bin/sh
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
1 65 cron.daily run-parts /etc/cron.daily
7 70 cron.weekly run-parts /etc/cron.weekly
30 75 cron.monthly run-parts /etc/cron.monthly

conclusion

Voilà présentés les principaux outils de programmation des tâches sous Linux. D'autres outils existent, comme fcron qui comblerait certaines failles de sécurité de cron

N'hésitez pas à me faire parvenir vos remarques et ajouts divers sur le contenu de cet article.

Cette page est issue de la documentation 'pré-wiki' de Léa a été convertie avec HTML::WikiConverter. Elle fut créée par Anne le 01/01/2003.