| Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente |
| cron [Le 27/05/2026, 13:13] – [Choix de l'utilisateur Cron] christophe c | cron [Le 27/05/2026, 20:24] (Version actuelle) – [Choix de l'utilisateur cron] note important -> warning krodelabestiole |
|---|
| {{tag>système administration}} | {{tag>système administration}} |
| |
| ---- | ====== Programmer des tâches avec cron ====== |
| | |
| | ===== Qu'est-ce que cron ===== |
| | |
| | **[[wpfr>cron]]** est une application permettant d'exécuter automatiquement des scripts, des commandes ou d'autres applications à une date et une heure spécifiée précise, ou selon un cycle défini à l’avance. |
| |
| ====== Programmer des tâches avec CRON ====== | Chaque [[:utilisateur]] possède un fichier ''crontab'' associé, lui permettant d'indiquer les actions à exécuter.\\ |
| | **cron** est parfois appelé « planificateur de tâches » ou « gestionnaire de tâches planifiées ». |
| |
| ===== Qu'est-ce que Cron ===== | <note>Sur les systèmes modernes, **cron** tend à être remplacé par des [[:creer_un_service_avec_systemd#qu_est_ce_qu_un_timer|timers]] [[:systemd]].</note> |
| **Cron** est un programme pour exécuter automatiquement des scripts, des commandes ou des logiciels à une date et une heure spécifiée précise, ou selon un cycle défini à l’avance. | |
| |
| Chaque utilisateur a un fichier **Crontab**, lui permettant d'indiquer les actions à exécuter.\\ | ==== Distinction avec Anacron ==== |
| Cron est parfois appelé « planificateur de tâches » ou « gestionnaire de tâches planifiées ». | |
| |
| ====Distinction avec Anacron==== | * **cron** est plutôt utilisé pour des machines à fonctionnement permanent (comme les serveurs). |
| Cron est plutôt utilisé pour des machines à fonctionnement permanent (comme les serveurs).\\ | * **[[:Anacron]]** est plutôt utilisé pour des machines à fonctionnement discontinu (comme les ordinateurs personnels). |
| [[Anacron]] est plutôt utilisé pour des machines à fonctionnement discontinu (comme les PC). | |
| |
| Cron a plus d'options qu'Anacron. Comme ce dernier, il peut lancer une tâche à un intervalle déterminé : par exemple chaque 5e jour de la semaine, chaque heure, ou chaque mois. Contrairement à Anacron, il peut aussi lancer une tâche à un moment pré-déterminé (« le 14 janvier 2018 à 15h 30 »). \\ | **cron** a plus d'options qu'**Anacron**. Comme ce dernier, il peut lancer une tâche à un intervalle déterminé : par exemple chaque 5e jour de la semaine, chaque heure, ou chaque mois. Contrairement à **Anacron**, il peut aussi lancer une tâche à un moment pré-déterminé (« le 14 janvier 2018 à 15h 30 »).\\ |
| Limite par rapport à Anacron : si la machine n'est pas allumée, la tâche n'est pas lancée, et ne le sera jamais, même après le re-démarrage. __Elle est perdue__. Les prochaines seront évidement lancées, si la machine est allumée. | Limite par rapport à **Anacron** : si la machine n'est pas allumée, la tâche n'est pas lancée, et ne le sera jamais, même après le re-démarrage. Elle est perdue. Les prochaines seront évidement lancées, si la machine est allumée. |
| |
| [[Anacron]] n'utilise que des indications de temps relatives (« une fois par jour / par semaine / par mois »). Autre différence d'avec Cron, si vous avez demandé une tâche toute les semaines, et que votre PC est démarré seulement au bout de 10 jours, Anacron constatera le retard, et lancera donc la tâche juste après le démarrage de votre PC. | **[[:Anacron]]** n'utilise que des indications de temps relatives (« une fois par jour / par semaine / par mois »). Autre différence d'avec **cron**, si vous avez demandé une tâche toute les semaines, et que votre PC est démarré seulement au bout de 10 jours, **Anacron** constatera le retard, et lancera donc la tâche juste après le démarrage de votre PC. |
| |
| Les 2 logiciels peuvent être utilisés sur un PC régulièrement éteint, mais Anacron a le gros avantage de lancer tous les traitements en retard à chaque allumage du PC, même si ces derniers sont peu nombreux. Avec Cron, des allumages PC trop intermittents risquent d'annuler une grande partie des traitements programmés. | Les 2 applications peuvent être utilisées sur un PC régulièrement éteint, mais **Anacron** a le gros avantage de lancer tous les traitements en retard à chaque allumage de l'ordinateur, même si ces derniers sont peu nombreux. Avec **cron**, des allumages PC trop intermittents risquent d'annuler une grande partie des traitements programmés. |
| |
| La syntaxe de Cron est plus complexe que celle d'Anacron. | La syntaxe de **cron** est plus complexe que celle d'**Anacron**. |
| |
| ===== Choix de l'utilisateur Cron ===== | ===== Choix de l'utilisateur cron ===== |
| Il est important de définir clairement sous quel compte utilisateur est lancé **cron**. Ce peut-être vous (votre //user//), ou ce peut-être //root// (utilisateur qui a tous les droits). | |
| |
| Pour des opérations demandant normalement un mot de passe, il faudra utiliser **cron //root//**. En effet, l'utilisateur //root// peut **tout** faire sans mot de passe. **/!\ Soyez prudents avec ces scripts, ils peuvent tout faire, y compris casser votre système !!** | Il est important de définir clairement sous quel compte [[:utilisateur]] est lancé **cron**. Ce peut-être vous (votre //user//), ou ce peut-être //root// (utilisateur qui a tous les droits). |
| |
| Pour des opérations en espace utilisateur (dans votre /home/), donc sans mot de passe, utilisez le **cron** de votre compte utilisateur. | Pour des opérations demandant normalement un mot de passe, il faudra utiliser **cron** en //root//. En effet, l'utilisateur //root// peut tout faire sans mot de passe. |
| | <note warning>Soyez prudents avec ces scripts, ils peuvent tout faire, y compris casser votre système !</note> |
| |
| Pour lancer le **cron //root//** : **sudo crontab -e**. Pour consulter ce cron sans l'ouvrir : **sudo contrab -l** | Pour des opérations en espace utilisateur (dans votre [[:arborescence#répertoire personnel]] ''/home/$USER''), donc sans mot de passe, utilisez le **cron** de votre compte [[:utilisateur]]. |
| |
| Pour lancer le cron de votre espace utilisateur : **crontab -e**. Pour consulter ce cron sans l'ouvrir : **contrab -l** | Pour lancer le **cron** de votre espace [[:utilisateur]] : ''crontab -e''. Pour consulter ce **cron** sans l'ouvrir : ''contrab -l''. |
| |
| ===== Comment fonctionne Cron ===== | Pour lancer le **cron** //root// : ''sudo crontab -e''. Pour consulter ce **cron** sans l'ouvrir : ''sudo contrab -l''. |
| |
| Les tâches planifiées cron sont définies au niveau du système dans le fichier /etc/crontab et dans le dossier /etc/cron.d/\\ | ===== Comment fonctionne cron ===== |
| Pour modifier vos tâches planifiées tapez : **crontab -e** ou **sudo crontab -e** (lance un éditeur du fichier crontab)\\ | |
| |
| Voici une courte description de la structure d'une entrée dans un fichier crontab. Les champs à renseigner sont __dans l'ordre__ | Les tâches planifiées **cron** sont définies au niveau du système dans le fichier ''/etc/crontab'' et dans le répertoire ''/etc/cron.d/''.\\ |
| | Pour modifier vos tâches planifiées entrez : ''crontab -e'' ou ''sudo crontab -e'' (lance un éditeur du fichier ''crontab''). |
| |
| * //minute// de lancement (les minutes se numérotent de 0 à 59) | Voici une courte description de la structure d'une entrée dans un fichier ''crontab''. Les champs à renseigner sont, //dans l'ordre// : |
| * //heure// de lancement (les heures se numérotent de 0 à 23) | - //minute// de lancement (les minutes se numérotent de 0 à 59) |
| * //jours dans le mois// de lancement (les jours se numérotes de 1 à 31) | - //heure// de lancement (les heures se numérotent de 0 à 23) |
| * //mois// de lancement (les mois se numérotent de 1 à 12, ou s'énoncent par leur libellé abrégé anglais - jan ; feb ; mar ; apr ; ...) | - //jours dans le mois// de lancement (les jours se numérotes de 1 à 31) |
| * //jour de la semaine// de lancement (les jours se numérotent de 1 (lundi) à 7 (dimanche), ou s'énoncent par leur libellé abrégé anglais - sun ; mon ; tue ; wed ; thu ; fri ; sat) | - //mois// de lancement (les mois se numérotent de 1 à 12, ou s'énoncent par leur libellé abrégé anglais - jan ; feb ; mar ; apr ; ...) |
| * La commande à lancer. | - //jour de la semaine// de lancement (les jours se numérotent de 1 (lundi) à 7 (dimanche), ou s'énoncent par leur libellé abrégé anglais - sun ; mon ; tue ; wed ; thu ; fri ; sat) |
| Un champ contenant une étoile ** * ** signifie '**tous**' => dans le champs 'mois', ** * ** signifie donc : 'a lancer chaque mois') : | - La commande à lancer. |
| | Un champ contenant une étoile ''*'' signifie '//tous//' => dans le champs "mois", ''*'' signifie donc : "//à lancer chaque mois//"). |
| |
| Récapitulatif des 5 premiers champs : | Récapitulatif des 5 premiers champs : |
| |
| ---- | ---- |
| Si __//jour du mois//__ et __//mois//__ sont définis, __//jour de la semaine//__ n'est pas nécessaire. Cependant, si le champ est indiqué en plus, la commande sera exécutée à la date //jour du mois// et //mois// mais AUSSI tous les //jour de la semaine// définis. | Si //jour du mois// et //mois// sont définis, //jour de la semaine// n'est pas nécessaire. Cependant, si le champ est indiqué en plus, la commande sera exécutée à la date //jour du mois// et //mois// mais AUSSI tous les //jour de la semaine// définis. |
| Exemple avec <code>0 0 13 1 5 tâche</code> | Exemple avec <code>0 0 13 1 5 tâche</code> |
| La "tâche" (non définie ici) sera exécutée 0mn et 0H après le démarrage, le 13e jour du 1er mois (janvier) __ET__ tous les vendredis (5e J. de la semaine). | La "tâche" (non définie ici) sera exécutée 0 min et 0 h après le démarrage, le 13e jour du 1er mois (janvier) //et// tous les vendredis (5e jour de la semaine). |
| |
| ---- L'exemple ci-dessous exécutera ///usr/bin/apt-get update// à 3:05 (5e minute de la 3e heure), chaque jour de chaque mois (les * dans "jour", "mois" et "jours de la semaine"), avec les droits de l'utilisateur **nomdutilisateur**. | ---- |
| | L'exemple ci-dessous exécutera ''/usr/bin/apt-get update'' à 3:05 (5e minute de la 3e heure), chaque jour de chaque mois (les ''*'' dans "jour", "mois" et "jours de la semaine"), avec les droits de l'utilisateur //nomdutilisateur//. |
| <code> | <code> |
| 5 3 * * * nomdutilisateur /usr/bin/apt-get update | 5 3 * * * nomdutilisateur /usr/bin/apt-get update |
| </code> | </code> |
| ---- Vous pouvez faire tourner **cron** toutes les 5 minutes, entre 9H à 17H, et uniquement du lundi au vendredi, avec un message "Où en es tu ?" (on met * pour les colonnes "jour dans le mois" et "mois", puisqu'on utilise pas ces données) : | ---- |
| | Vous pouvez faire tourner **cron** toutes les 5 minutes, entre 9 h à 17 h, et uniquement du lundi au vendredi, avec un message "Où en es tu ?" (on met ''*'' pour les colonnes "jour dans le mois" et "mois", puisqu'on utilise pas ces données) : |
| <code> | <code> |
| */5 9-17 * * mon,tue,wed,thu,fri wall "Où en es tu ?" | */5 9-17 * * mon,tue,wed,thu,fri wall "Où en es tu ?" |
| Il existe des raccourcis intéressants : | Il existe des raccourcis intéressants : |
| |
| * @reboot # se lance au boot avec les droits utilisateurs, bien commode | * ''@reboot'' se lance au boot avec les droits utilisateurs, bien commode |
| * @yearly | * ''@yearly'' |
| * @annually | * ''@annually'' |
| * @monthly | * ''@monthly'' |
| * @weekly | * ''@weekly'' |
| * @daily | * ''@daily'' |
| * @midnight | * ''@midnight'' |
| * @hourly | * ''@hourly'' |
| |
| Exemples de lancements de tâches : | Exemples de lancements de tâches : |
| |
| chaque demie-heure (***/30** est une instruction, pas deux) | chaque demie-heure (''*/30'' est une instruction, pas deux) |
| <code>*/30 * * * * commande</code> | <code>*/30 * * * * commande</code> |
| |
| <code>30 * * * * commande</code> | <code>30 * * * * commande</code> |
| |
| chaque heure, mais uniquement entre 9h00 et 5h00 | chaque heure, mais uniquement entre 9h00 et 5h00 : |
| <code>0 9-5 * * * commande</code> | <code>0 9-5 * * * commande</code> |
| |
| http://www.cronmaker.com | http://www.cronmaker.com |
| |
| ===== Commandes pour gérer les tâches planifiées Cron ===== | ===== Commandes pour gérer les tâches planifiées cron ===== |
| |
| Pour examiner les tâches planifiées de l'utilisateur courant (le contenu de votre **crontab**), tapez : | Pour examiner les tâches planifiées de l'utilisateur courant (le contenu de votre ''crontab''), entrez : |
| | <code bash>crontab -l</code> |
| |
| <code bash> | Pour modifier vos tâches planifiées entrez : |
| crontab -l | |
| </code> | |
| | |
| Pour modifier vos tâches planifiées tapez : | |
| <code bash>crontab -e</code> | <code bash>crontab -e</code> |
| pour celles nécessitant normalement un mot de passe (qui dès lors ne sera pas demandé) : | pour celles nécessitant normalement un mot de passe (qui dès lors ne sera pas demandé) : |
| <code bash>sudo crontab -e -u nom_utilisateur</code> | <code bash>sudo crontab -e -u nom_utilisateur</code> |
| |
| Quand vous sortez de l'éditeur, le nouveau fichier **crontab** sera installé. Le fichier est stocké dans ///var/spool/cron/crontabs/<user>// mais doit seulement être modifié par l'intermédiaire de la commande **crontab**. | Quand vous sortez de l'éditeur, le nouveau fichier **crontab** sera installé. Le fichier est stocké dans ''/var/spool/cron/crontabs/$USER'' mais doit seulement être modifié par l'intermédiaire de la commande ''[[man>crontab]]''. |
| |
| <note important>Il faut auparavant indiquer que l'utilisateur a le droit d'utiliser crontab.\\ | <note important>Il faut auparavant indiquer que l'utilisateur a le droit d'utiliser ''crontab''.\\ |
| Pour cela il faut créer un fichier **///etc/cron.allow//** et y saisir le nom des utilisateurs autorisés à utiliser crontab.</note> | Pour cela il faut créer un fichier ''/etc/cron.allow'' et y saisir le nom des utilisateurs autorisés à utiliser ''crontab''.</note> |
| |
| L'éditeur utilisé pour modifier la crontab peut être modifié par la commande : | L'éditeur utilisé pour modifier le ''crontab'' peut être modifié par la commande : |
| <code> | <code> |
| sudo update-alternatives --config editor | sudo update-alternatives --config editor |
| select-editor | select-editor |
| | |
| <note tip> Lors du premier accès à « crontab -e » un menu apparaît et donne le choix de l'éditeur à utiliser.</note> | <note tip> Lors du premier accès à ''crontab -e'' un menu apparaît et donne le choix de l'éditeur à utiliser.</note> |
| |
| Certains environnements de bureau, comme KDE dans sa « Configuration du système », offrent une interface graphique pour gérer les tâches cron. | Certains environnements de bureau, comme KDE dans sa « Configuration du système », offrent une interface graphique pour gérer les tâches **cron**. |
| |
| ===== Lancement graphique ===== | ===== Lancement graphique ===== |
| Par défaut, l'exécution de **cron** n'affiche rien. Si vous avez besoin de démarrer une interface graphique par exemple pour utiliser [[zenity|zenity]], kdialog, dialog ou encore [[totem|totem]], [[vlc|vlc]], ... Il vous faudra ajouter un **DISPLAY=:0** devant la commande lancée. Exemple : | |
| | Par défaut, l'exécution de **cron** n'affiche rien. Si vous avez besoin de démarrer une interface graphique par exemple pour utiliser [[:zenity]], kdialog, dialog ou encore [[:totem]], [[:VLC]], ... Il vous faudra ajouter un ''DISPLAY=:0'' devant la commande lancée. Exemple : |
| <code> | <code> |
| */5 * * * * DISPLAY=:0 zenity --info --text="Toto va bien" | */5 * * * * DISPLAY=:0 zenity --info --text="Toto va bien" |
| </code> | </code> |
| |
| <note important>Il est parfois nécessaire de faire "xhost +" dans un terminal pour autoriser l'accès à X</note> | <note important> |
| | Il est parfois nécessaire de faire ''xhost +'' dans un terminal pour autoriser l'accès à [[:Xorg]]. |
| | |
| | FIXME : À mettre à jour concernant [[:Wayland]]. |
| | </note> |
| |
| ===== Caractères UTF8 ===== | ===== Caractères UTF8 ===== |
| | |
| Si vous utilisez un script nécessitant des caractères tels que des accents, n'oubliez pas d'ajouter un export **LANG="fr_FR.UTF-8"** ou **LANG="fr_BE.UTF-8"** au début de ce script. | Si vous utilisez un script nécessitant des caractères tels que des accents, n'oubliez pas d'ajouter un export **LANG="fr_FR.UTF-8"** ou **LANG="fr_BE.UTF-8"** au début de ce script. |
| |
| ===== Chemin des scripts, commandes à exécuter ou fichiers à utiliser ===== | ===== Chemin des scripts, commandes à exécuter ou fichiers à utiliser ===== |
| Une tâche cron est exécutée dans un shell non connecté (non-login) et non interactif. Les variables d'environnement habituelles et en particulier **PATH** ne sont pas connues. Cron n'a donc pas de PATH par défaut. | |
| | Une tâche **cron** est exécutée dans un shell non connecté (non-login) et non interactif. Les variables d'environnement habituelles et en particulier ''[[:variables_d_environnement#variables_liees_aux_emplacements_de_fichiers|$PATH]]'' ne sont pas connues. **cron** n'a donc pas de ''[[:variables_d_environnement#variables_liees_aux_emplacements_de_fichiers|$PATH]]'' par défaut. |
| |
| Il faut donc :\\ | Il faut donc :\\ |
| - soit mettre les emplacements __complets__ des exécutables dans les commandes et les scripts appelés par cron, par exemple : | - soit mettre les emplacements //complets// des exécutables dans les commandes et les scripts appelés par **cron**, par exemple : |
| <code>/usr/bin/zenity --info --text="Toto va bien!"</code> | <code>/usr/bin/zenity --info --text="Toto va bien!"</code> |
| - soit ajouter une ligne de PATH dans le fichier crontab, __avant__ les appels de scripts. Cette ligne définie où il est très probable que se trouveront les programmes appelés : | - soit ajouter une ligne de ''[[:variables_d_environnement#variables_liees_aux_emplacements_de_fichiers|$PATH]]'' dans le fichier ''crontab'', //avant// les appels de scripts. Cette ligne définie où il est très probable que se trouveront les programmes appelés : |
| <code>PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin</code> | <code>PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin</code> |
| - Soit faire les deux si on est très prudent :). | - Soit faire les deux si on est très prudent :). |
| ===== Utilisation des répertoires /etc/cron.hourly, daily, weekly, monthly ===== | ===== Utilisation des répertoires /etc/cron.hourly, daily, weekly, monthly ===== |
| |
| Si vous avez examiné le fichier /etc/crontab de votre système, vous avez remarqué qu'il contient des tâches pour exécuter toutes les heures, jours, semaines, mois les fichiers contenus dans les dossiers /etc/cron.hourly, daily, weekly, monthly. | Si vous avez examiné le fichier ''/etc/crontab'' de votre système, vous avez remarqué qu'il contient des tâches pour exécuter toutes les heures, jours, semaines, mois les fichiers contenus dans les répertoires ''/etc/cron.hourly'', ''/etc/cron.daily'', ''/etc/cron.weekly'', ''/etc/cron.monthly''. |
| |
| Si vous avez besoin qu'un script soit exécuté toutes les heures au niveau du système (par root), il suffit donc de le placer dans le dossier /etc/cron.hourly et de le rendre exécutable. De même s'il s'agit d'une tâche quotidienne (daily), hebdomadaire (weekly) ou mensuelle (monthly). | Si vous avez besoin qu'un script soit exécuté toutes les heures au niveau du système (par //root//), il suffit donc de le placer dans le répertoire ''/etc/cron.hourly'' et de le rendre exécutable. De même s'il s'agit d'une tâche quotidienne (//daily//), hebdomadaire (//weekly//) ou mensuelle (//monthly//). |
| |
| ===== Utilisation du répertoire /etc/cron.d ===== | ===== Utilisation du répertoire /etc/cron.d ===== |
| | |
| IL est possible d'éditer des services à exécuter automatiquement en rajoutant un fichier du nom que l'on souhaite dans le répertoire /etc/cron.d | IL est possible d'éditer des services à exécuter automatiquement en rajoutant un fichier du nom que l'on souhaite dans le répertoire /etc/cron.d |
| |
| Attention contrairement aux lignes d'un fichier crontab, elles doivent préciser quel utilisateur (nom_utilisateur dans l'exemple ci-dessous) exécute le script : | Attention contrairement aux lignes d'un fichier ''crontab'', elles doivent préciser quel utilisateur (nom_utilisateur dans l'exemple ci-dessous) exécute le script : |
| <code>* * * * * nom_utilisateur /bin/touch /home/me/ding_dong</code> | <code>* * * * * nom_utilisateur /bin/touch /home/me/ding_dong</code> |
| |
| ===== Autres Considérations ===== | ===== Autres Considérations ===== |
| |
| Les commandes ci-dessus sont stockées dans un fichier **crontab** appartenant à votre compte d'utilisateur et exécutées avec votre niveau des permissions. Si vous voulez exécuter, régulièrement, une commande exigeant un plus haut niveau de permission (root), vous devez utiliser le fichier **crontab** root (ou racine) : | Les commandes ci-dessus sont stockées dans un fichier ''crontab'' appartenant à votre compte d'utilisateur et exécutées avec votre niveau des permissions. Si vous voulez exécuter, régulièrement, une commande exigeant un plus haut niveau de permission (//root//), vous devez utiliser le fichier ''crontab'' //root// : |
| |
| <code>sudo crontab -e</code> | <code>sudo crontab -e</code> |
| |
| Remarque : cette commande édite directement le fichier // /var/spool/cron/crontabs/root// | <note>Cette commande édite directement le fichier ''/var/spool/cron/crontabs/root''.</note> |
| |
| Une autre façon de créer une tâche planifiée devant être exécutée par root est d'ajouter une entrée au fichier /etc/crontab ou de créer un nouveau fichier dans /etc/cron.d (cf. point précédent) en précisant bien root comme nom d'utilisateur. | Une autre façon de créer une tâche planifiée devant être exécutée par //root// est d'ajouter une entrée au fichier ''/etc/crontab'' ou de créer un nouveau fichier dans ''/etc/cron.d'' (cf. point précédent) en précisant bien //root// comme nom d'utilisateur. |
| |
| ==== Tests ==== | ==== Tests ==== |
| |
| Il est important de vérifier que vos travaux dans **cron** fonctionnent comme prévu. Une méthode pour faire un test est de paramétrer la tâche dans le **crontab** pour qu'elle s'exécute quelques minutes plus tard et contrôler le résultat, avant de mettre la synchronisation de cette tâche à la bonne heure. Vous pouvez également trouver utile d'envoyer les retours des commandes dans un fichier texte pour voir les succès ou les échecs, par exemple : | Il est important de vérifier que vos travaux dans **cron** fonctionnent comme prévu. Une méthode pour faire un test est de paramétrer la tâche dans le ''crontab'' pour qu'elle s'exécute quelques minutes plus tard et contrôler le résultat, avant de mettre la synchronisation de cette tâche à la bonne heure. Vous pouvez également trouver utile d'envoyer les retours des commandes dans un fichier texte pour voir les succès ou les échecs, par exemple : |
| |
| <code bash> | <code bash> |
| </code> | </code> |
| |
| Une autre façon de contrôler la bonne exécution des tâches cron est d'utiliser sa capacité à envoyer des courriels. | Une autre façon de contrôler la bonne exécution des tâches **cron** est d'utiliser sa capacité à envoyer des courriels. |
| Pour cela il suffit de renseigner la variable MAILTO dans votre fichier crontab, exemple : | Pour cela il suffit de renseigner la variable MAILTO dans votre fichier ''crontab'', exemple : |
| <code bash>MAILTO="jean.dupont@example.com"</code> | <code bash>MAILTO="jean.dupont@example.com"</code> |
| <note important>pour que cela fonctionne il faut que votre machine soit capable d'envoyer des courriels. (voir par exemple : [[msmtp|MSMTP]] ou [[postfix_systeme_satellite|Système Satellite pour Postfix]], [[exim4-satellite|Système satellite pour exim4]])</note>\\ | <note important>Pour que cela fonctionne il faut que votre machine soit capable d'envoyer des courriels. (voir par exemple : [[:msmtp]] ou les systèmes satellites pour [[:postfix_systeme_satellite|Postfix]] ou [[:exim4-satellite|exim4]]).</note> |
| Au contraire, si vous ne voulez pas envoyer d’emails, ajouter simplement comme 1ère ligne utile <code bash>MAILTO=""</code> | Au contraire, si vous ne voulez pas envoyer d’emails, ajouter simplement comme 1ère ligne utile ''MAILTO=""''. |
| |
| Pour plus d'informations, lisez les pages du //man// pour **cron** et **crontab** (le //man// est détaillé sur [[:tutoriel:console_ligne_de_commande|les commandes basiques]]). | Pour plus d'informations, lisez les pages du //man// pour **[[man>cron]]** et ''[[man>crontab]]'' (le //man// est détaillé sur [[:tutoriel:console_ligne_de_commande|les commandes basiques]]). |
| Sur une machine qui n'est pas allumée en permanence, **[[anacron|anacron]]** (installé par défaut) permet de s'assurer que les taches cron sont bien exécutées en vérifiant à intervalles régulier si une tâche n'est pas en retard. | |
| |
| | Sur une machine qui n'est pas allumée en permanence, **[[:anacron]]** (installé par défaut) permet de s'assurer que les taches **cron** sont bien exécutées en vérifiant à intervalles régulier si une tâche n'est pas en retard. |
| |
| ==== Log ==== | ==== Journal ==== |
| Par défaut on retrouve des logs de commandes CRON dans ///var/log/syslog// mais ce n'est pas très pratique.\\ | |
| Pour activer le log spécifique de CRON:\\ | Par défaut on retrouve des logs de commandes **cron** dans ''/var/log/syslog'' mais ce n'est pas très pratique. |
| Éditer le fichier ///etc/rsyslog.d/50-default.conf// qui est appelé par ///etc/rsyslog.conf// et décommenter la ligne | |
| | Pour activer le log spécifique de **cron**:\\ |
| | Éditer le fichier ''/etc/rsyslog.d/50-default.conf'' qui est appelé par ''/etc/rsyslog.conf'' et décommenter la ligne : |
| <code bash> | <code bash> |
| cron.* /var/log/cron.log | cron.* /var/log/cron.log |
| sudo systemctl restart cron | sudo systemctl restart cron |
| </code> | </code> |
| Il ne reste plus qu'à surveiller les logs de CRON: | Il ne reste plus qu'à surveiller les logs de **cron**: |
| <code bash> | <code bash> |
| sudo tail -f /var/log/cron.log | sudo tail -f /var/log/cron.log |
| </code> | </code> |
| |
| et si vous voulez des tâches silencieuses ((https://unix.stackexchange.com/questions/163352/what-does-dev-null-21-mean-in-this-article-of-crontab-basics)), ajouter à la fin de vos lignes CRON <code bash> > /dev/null 2>&1</code> pour rediriger les messages ET les erreurs vers le « trou noir ». | Si on préfère des tâches silencieuses((https://unix.stackexchange.com/questions/163352/what-does-dev-null-21-mean-in-this-article-of-crontab-basics)), ajouter à la fin des lignes **cron** : |
| ===== Liens ===== | <code bash> > /dev/null 2>&1</code> |
| * [[https://help.ubuntu.com/community/CronHowto]] (EN) | pour rediriger les messages //et// les erreurs vers le « trou noir ». |
| | |
| | ===== Voir aussi ===== |
| | |
| | * **(//en//)** [[https://help.ubuntu.com/community/CronHowto]] |
| * [[http://www.math-linux.com/spip.php?article16|Programmation des tâches régulières : crontab]] | * [[http://www.math-linux.com/spip.php?article16|Programmation des tâches régulières : crontab]] |
| * [[:nano|Editeur de texte de Crontab : gnu nano]] | * [[:nano|Éditeur de texte GNU nano]] |
| * [[incron]] : effectuer une action, commande(s), scripts, etc, en cas de modifications de fichiers ou de répertoires donnés | * [[:incron]] : effectuer une action, commande(s), scripts, etc, en cas de modifications de fichiers ou de répertoires donnés |
| * [[https://www.easycron.com/|EasyCron - Cron Jobs Alternatives]] | * [[https://www.easycron.com/|EasyCron - Cron Jobs Alternatives]] |
| * [[:Anacron]] : planificateur de commande « anachronique » | * [[:Anacron]] : planificateur de commande « anachronique » |
| * [[fcron]] : programmer des tâches devant être exécutées/ | * [[:fcron]] : programmer des tâches devant être exécutées/ |
| * [[https://askubuntu.com/questions/23009/why-crontab-scripts-are-not-working|why crontab scripts are not working?]] | * [[https://askubuntu.com/questions/23009/why-crontab-scripts-are-not-working|why crontab scripts are not working?]] |
| |
| ---- | ---- |
| | //[[:Contributeurs]] : Martigo, l'entreprise Simplistay, [[:utilisateurs:krodelabestiole]].// |
| //Contributeurs : Martigo, [[:contributeurs|Les contributeurs d'Ubuntu-fr]], l'entreprise Simplistay.// | |