publish: crontab

This commit is contained in:
Cédrix
2026-05-16 23:21:53 +02:00
parent 1253298c9c
commit a810eab5df
5 changed files with 164 additions and 166 deletions
@@ -1,11 +0,0 @@
{
"title": "crontab",
"_updated_at": "2026-05-16 21:21:51",
"slug": "cron",
"published": true,
"published_at": "2023-02-18 16:06",
"category": "Informatique",
"tags": [],
"seo_title": "",
"seo_description": ""
}
@@ -1,116 +0,0 @@
# crontab
![Nom de la section](dummy.png)
**cron** est un démon Unix qui exécute, chaque minute, les tâches planifiées par les utilisateurs. La commande **crontab** (contraction de *chrono table*, « table de planification ») permet de consulter et modifier ces tâches.
Chaque utilisateur dispose de sa propre table ; le démon `cron`, lancé par **root**, exécute chaque tâche sous l'identité de son propriétaire.
## Format d'une ligne
Chaque ligne d'une crontab suit le format suivant :
```
mm hh jj MMM JJJ commande
```
| Champ | Plage | Description |
| ----- | ----- | ----------- |
| `mm` | 059 | Minute |
| `hh` | 023 | Heure |
| `jj` | 131 | Jour du mois |
| `MMM` | 112 | Mois |
| `JJJ` | 06 | Jour de la semaine (0 = dimanche) |
## Lister les tâches
Afficher la table de l'utilisateur connecté :
```
crontab -l
```
## Mots-clés
Plusieurs mots-clés peuvent remplacer le code horaire :
| Mot-clé | Description | Équivalent |
| ------- | ----------- | ---------- |
| `@reboot` | Au démarrage | (aucun) |
| `@yearly` | Tous les ans | `0 0 1 1 *` |
| `@annually` | Tous les ans | `0 0 1 1 *` |
| `@monthly` | Tous les mois | `0 0 1 * *` |
| `@weekly` | Toutes les semaines | `0 0 * * 0` |
| `@daily` | Tous les jours | `0 0 * * *` |
| `@midnight` | Toutes les nuits | `0 0 * * *` |
| `@hourly` | Toutes les heures | `0 * * * *` |
## Éditer la table
Ouvrir la crontab de l'utilisateur connecté dans l'éditeur par défaut :
```
crontab -e
```
L'éditeur utilisé peut être modifié via la variable d'environnement `EDITOR` :
```
$ export EDITOR=nano
```
## Supprimer la table
```
crontab -r
```
## Remplacer la table
Remplacer la table courante par le contenu d'un fichier :
```
crontab <fichier>
```
## Rediriger les sorties
Par défaut, la sortie standard d'une tâche `cron` est envoyée par mail à son propriétaire. Pour la rediriger, on utilise la syntaxe shell habituelle :
```
mm hh jj MMM JJJ tâche > fichier1 2> fichier2
```
- `fichier1` reçoit la sortie standard
- `fichier2` reçoit l'erreur standard
Pour ignorer toute sortie :
```
>/dev/null 2>&1
```
## Inspecter l'activité
Afficher la date du dernier accès au script de `cron` (indicateur approximatif d'activité) :
```
ls -lut /etc/init.d/cron
```
Extraire les lignes relatives à `cron` dans le journal système :
```
grep -w cron /var/log/syslog
```
## Pour aller plus loin
Les tables sont stockées dans un fichier propre à chaque utilisateur :
- `/var/spool/cron/crontabs/<utilisateur>` sous Debian, MX Linux
- `/var/spool/cron/<utilisateur>` sous Red Hat, Fedora et CentOS
Une table système centralisée existe également dans `/etc/crontab`.
Pour les postes qui ne restent pas allumés en permanence, l'utilitaire **anacron** prend le relais : il exécute, au démarrage, les tâches qui auraient dû tourner pendant que la machine était éteinte.
+64 -35
View File
@@ -1,87 +1,116 @@
# crontab
![Nom de la section](dummy.png)
Programme Unix qui exécute toutes les minutes un ensemble de taches prédéterminées.
Sous Linux, le programme **cron** s'appelle **crontab**, concaténation de **c**h**ron**o **tab**le, "table de planification". Il est exécuté par **root** et permet de s'adapter à l'identité à chacun des utilisateurs.
**cron** est un démon Unix qui exécute, chaque minute, les tâches planifiées par les utilisateurs. La commande **crontab** (contraction de *chrono table*, « table de planification ») permet de consulter et modifier ces tâches.
## - Liste la table des tâches
Afficher la liste des tâches pour l'utilisateur connecté
Chaque utilisateur dispose de sa propre table ; le démon `cron`, lancé par **root**, exécute chaque tâche sous l'identité de son propriétaire.
## Format d'une ligne
Chaque ligne d'une crontab suit le format suivant :
```
mm hh jj MMM JJJ commande
```
| Champ | Plage | Description |
| ----- | ----- | ----------- |
| `mm` | 059 | Minute |
| `hh` | 023 | Heure |
| `jj` | 131 | Jour du mois |
| `MMM` | 112 | Mois |
| `JJJ` | 06 | Jour de la semaine (0 = dimanche) |
## Lister les tâches
Afficher la table de l'utilisateur connecté :
```
crontab -l
```
## - Mots clés
Des mots-clé peuvent remplacer le code horaire.
## Mots-clés
| mot-clé | description | équivalent |
Plusieurs mots-clés peuvent remplacer le code horaire :
| Mot-clé | Description | Équivalent |
| ------- | ----------- | ---------- |
| @reboot | Au démarrage | Aucun |
| @yearly | Tous les ans | 0 0 1 1 * |
| @annually | Tous les ans | 0 0 1 1 * |
| @monthly | Tous les mois | 0 0 1 * * |
| @weekly | Toutes les semaines | 0 0 * * 0 |
| @daily | Tous les jours | 0 0 * * * |
| @midnight | Toutes les nuits | 0 0 * * * |
| @hourly | Toutes les heures | 0 * * * * |
| `@reboot` | Au démarrage | (aucun) |
| `@yearly` | Tous les ans | `0 0 1 1 *` |
| `@annually` | Tous les ans | `0 0 1 1 *` |
| `@monthly` | Tous les mois | `0 0 1 * *` |
| `@weekly` | Toutes les semaines | `0 0 * * 0` |
| `@daily` | Tous les jours | `0 0 * * *` |
| `@midnight` | Toutes les nuits | `0 0 * * *` |
| `@hourly` | Toutes les heures | `0 * * * *` |
## - Éditer la tables des tâches
Éditer la liste des tâches pour l'utilisateur connecté
## Éditer la table
Ouvrir la crontab de l'utilisateur connecté dans l'éditeur par défaut :
```
crontab -e
```
L'éditeur par défaut est exécuté pour éditer la table des tâches. Il est modifiable grâce à la variable d'environnement :
L'éditeur utilisé peut être modifié via la variable d'environnement `EDITOR` :
```
$ export EDITOR=nano
```
## - Supprimer la tables des tâches
Supprimer la liste des tâches pour l'utilisateur connecté
## Supprimer la table
```
crontab -r
```
## - Remplacer la tables des tâches
Remplacer la liste des tâches pour l'utilisateur connecté par une nouvelle table contenu dans `<fichier>`
## Remplacer la table
Remplacer la table courante par le contenu d'un fichier :
```
crontab <fichier>
```
## - Journalisation
La sortie standard pour une tache **cron** est l'envoi d'un mail. Pour modifier la sortie, il faut utiliser la syntaxe suivante :
## Rediriger les sorties
Par défaut, la sortie standard d'une tâche `cron` est envoyée par mail à son propriétaire. Pour la rediriger, on utilise la syntaxe shell habituelle :
```
mm hh jj MMM JJJ tâche > fichier1 2> fichier2
mm hh jj MMM JJJ tâche > fichier1 2> fichier2
```
- `fichier1` contient la sortie standard
- `fichier2` contient l'erreur standard
- `fichier1` reçoit la sortie standard
- `fichier2` reçoit l'erreur standard
Pour ignorer toute sortie :
Par exemple, pour ne rien afficher :
```
>/dev/null 2>&1
```
**Afficher l'horaire de la dernière tâche exécutée** pour l'ensemble des utilisateurs :
## Inspecter l'activité
Afficher la date du dernier accès au script de `cron` (indicateur approximatif d'activité) :
```
ls -lut /etc/init.d/cron
```
**Extraire du journal du système** les informations concernant la table **cron** :
Extraire les lignes relatives à `cron` dans le journal système :
```
grep -w cron /var/log/syslog
```
## - + d'infos
Les informations de planification sont stockées dans un fichier relatif à l'utilisateur. Par exemple :
## Pour aller plus loin
Les tables sont stockées dans un fichier propre à chaque utilisateur :
- `/var/spool/cron/crontabs/<utilisateur>` sous Debian, MX Linux
- `/var/spool/cron/<utilisateur>` sous Red Hat, Fedora et Cent OS
- `/var/spool/cron/<utilisateur>` sous Red Hat, Fedora et CentOS
En plus, il existe un table cron centralisée dans `/etc/crontab`.
Une table système centralisée existe également dans `/etc/crontab`.
Pour un poste de travail ne fonctionnant pas forcément toute une journée, l'application **anacron** permet de lancer les commandes qui dû l'être lorsque l'ordinateur était éteint.
Pour les postes qui ne restent pas allumés en permanence, l'utilitaire **anacron** prend le relais : il exécute, au démarrage, les tâches qui auraient dû tourner pendant que la machine était éteinte.
+13 -4
View File
@@ -4,15 +4,24 @@
"title": "crontab",
"author": "cedric@abonnel.fr",
"published": true,
"published_at": "2023-02-18 16:06:22",
"featured": false,
"published_at": "2023-02-18 16:06",
"created_at": "2023-02-18 16:06:22",
"updated_at": "2023-02-18 16:06:22",
"revisions": [],
"updated_at": "2026-05-16 21:21:52",
"revisions": [
{
"n": 1,
"date": "2026-05-16 21:21:52",
"comment": "Contenu modifié",
"title": "crontab"
}
],
"cover": "",
"files_meta": [],
"external_links": [],
"seo_title": "",
"seo_description": "",
"og_image": "",
"category": "Informatique"
"category": "Informatique",
"tags": []
}
@@ -0,0 +1,87 @@
# crontab
![Nom de la section](dummy.png)
Programme Unix qui exécute toutes les minutes un ensemble de taches prédéterminées.
Sous Linux, le programme **cron** s'appelle **crontab**, concaténation de **c**h**ron**o **tab**le, "table de planification". Il est exécuté par **root** et permet de s'adapter à l'identité à chacun des utilisateurs.
## - Liste la table des tâches
Afficher la liste des tâches pour l'utilisateur connecté
```
crontab -l
```
## - Mots clés
Des mots-clé peuvent remplacer le code horaire.
| mot-clé | description | équivalent |
| ------- | ----------- | ---------- |
| @reboot | Au démarrage | Aucun |
| @yearly | Tous les ans | 0 0 1 1 * |
| @annually | Tous les ans | 0 0 1 1 * |
| @monthly | Tous les mois | 0 0 1 * * |
| @weekly | Toutes les semaines | 0 0 * * 0 |
| @daily | Tous les jours | 0 0 * * * |
| @midnight | Toutes les nuits | 0 0 * * * |
| @hourly | Toutes les heures | 0 * * * * |
## - Éditer la tables des tâches
Éditer la liste des tâches pour l'utilisateur connecté
```
crontab -e
```
L'éditeur par défaut est exécuté pour éditer la table des tâches. Il est modifiable grâce à la variable d'environnement :
```
$ export EDITOR=nano
```
## - Supprimer la tables des tâches
Supprimer la liste des tâches pour l'utilisateur connecté
```
crontab -r
```
## - Remplacer la tables des tâches
Remplacer la liste des tâches pour l'utilisateur connecté par une nouvelle table contenu dans `<fichier>`
```
crontab <fichier>
```
## - Journalisation
La sortie standard pour une tache **cron** est l'envoi d'un mail. Pour modifier la sortie, il faut utiliser la syntaxe suivante :
```
mm hh jj MMM JJJ tâche > fichier1 2> fichier2
```
- `fichier1` contient la sortie standard
- `fichier2` contient l'erreur standard
Par exemple, pour ne rien afficher :
```
>/dev/null 2>&1
```
**Afficher l'horaire de la dernière tâche exécutée** pour l'ensemble des utilisateurs :
```
ls -lut /etc/init.d/cron
```
**Extraire du journal du système** les informations concernant la table **cron** :
```
grep -w cron /var/log/syslog
```
## - + d'infos
Les informations de planification sont stockées dans un fichier relatif à l'utilisateur. Par exemple :
- `/var/spool/cron/crontabs/<utilisateur>` sous Debian, MX Linux
- `/var/spool/cron/<utilisateur>` sous Red Hat, Fedora et Cent OS
En plus, il existe un table cron centralisée dans `/etc/crontab`.
Pour un poste de travail ne fonctionnant pas forcément toute une journée, l'application **anacron** permet de lancer les commandes qui dû l'être lorsque l'ordinateur était éteint.