====== DEMONS ====== ====== NOM ====== start-stop-daemon - lance ou arrête des démons-systèmes ===== SYNOPSIS ===== start-stop-daemon -S|--start options [--] arguments start-stop-daemon -K|--stop options start-stop-daemon -H|--help start-stop-daemon -V|--version ====== DESCRIPTION ====== On se sert de start-stop-daemon pour contrôler la création ou l'arrêt de processus-systèmes. On peut configurer start-stop-daemon avec les options --exec, --pidfile, --user, et **--name**, pour trouver les exemplaires présents d'un processus en fonctionnement. Avec l'action --start, start-stop-daemon vérifie l'existence d'un processus particulier. Quand existe un tel processus, start-stop-daemon ne fait rien et se termine avec un code d'erreur égal à 1 (0 si --oknodo est précisé). Quand un tel processus n'existe pas, un exemplaire de l'exécutable est lancé avec --exec, (ou, si c'est précisé, avec --startas). Tout argument donné après -- sur la ligne de commande est passé tel quel au programme qui doit être lancé. Si --retry est indiqué, start-stop-daemon vérifie que le (ou les) processus s'est terminé. Avec l'action --stop, start-stop-daemon vérifie aussi l'existence d'un processus particulier. Quand un tel processus existe start-stop-daemon lui envoie le signal précisé avec **--signal**, et se termine avec un code d'erreur égal à 0. Quand un tel processus n'existe pas start-stop-daemon se termine avec un code d'erreur égal à 1 (0 if --oknodo est précisé). **OPTIONS** * **-x|--exec executable** Cherche les processus qui sont des exemplaires de cet exécutable (selon /proc/pid/exe). * **-p|--pidfile pid-file** Cherche les processus dont les identifiants sont précisés dans pid-file. * **-u|--user nom-d-utilisateur|uid** Cherche les processus qui appartiennent à l'utilisateur défini par nom-d-utilisateur ou uid. * **-n|--name nom-de-processus** Cherche les processus dont le nom est nom-de-processus (selon /proc/pid/stat). * **-s|--signal signal** Avec l'action --stop, on définit le signal à envoyer au processus qui doit être arrêté (par défaut : signal 15). * **-R|--retry durée|action-prévue** Avec l'action --stop, start-stop-daemon doit vérifier que les processus se sont terminés. Il le fait pour tous les processus correspondants qui tournent, jusqu'à ce qu'il n'y en ait plus. Quand le processus ne se termine pas, il prend d'autres mesures déterminées par l'action-prévue. Si durée est indiqué plutôt que action-prévue, l'action-prévue signal/durée/KILL/durée est utilisé, où signal est le signal indiqué par --signal. action-prévue est une liste d'au moins deux items séparés par des barres obliques (/) ; Chaque item peut être de la forme -signal-number ou de la forme [-]signal-name, ce qui demande d'envoyer ce signal ; ou bien de la forme durée, ce qui demande d'attendre tant de secondes avant de terminer les processus, ou bien de la forme forever, ce qui demande de répéter constamment le reste de action-prévue, si nécessaire. Quand la fin de l'action-prévue est atteinte et que forever n'a pa été précisé, start-stop-daemon se termine avec un code d'erreur égal à 2. Quand une action-prévue est indiquée, tout signal donné par --signal est ignoré. * **-a | --startas chemin/nom** Avec l'action --start , lance le processus spécifié par chemin/nom. Si rien n'est précisé, c'est par défaut l'argument donné à --exec. * **-t | --test** Affiche les actions qui seraient entreprises et détermine la bonne valeur de retour, mais ne fait rien. * **-o | --oknodo** Retourne un code de sortie égal à 0 au lieu de 1 si rien n'est ou ne sera fait. * **-q | --quiet** N'affiche pas de messages d'information ; affiche seulement les messages d'erreur. * **-c | --chuid** Change l'utilisateur ou l'identifiant avant de lancer le processus. On peut aussi préciser un groupe an ajoutant un « : », puis le groupe ou un identifiant de la même façon qu'avec la commande « chown » (utilisateur:groupe). Quand on utilise cette option, on doit s'apercevoir que les groupes primaires ainsi que les groupes supplémentaires sont aussi déterminés, même si l'option « group » n'est pas spécifiée. L'option « group » sert seulement pour les groupes dont l'utilisateur n'est pas un membre régulier (c'est comme rendre membres d'un groupe-processus des utilisateurs génériques comme « nobody »). * **-r | --chroot root** Change de répertoire racine pour root avant de lancer le processus. Remarquez que le « pidfile » est aussi écrit après le changement de racine. * **-b | --background** est utilisé de manière classique pour les programmes qui ne « se détachent » pas d'eux-mêmes. Cette option oblige start-stop-daemon à se dupliquer (fork) avant de lancer le processus, et l'oblige à passer en arrière-plan. AVERTISSEMENT : start-stop-daemon ne peut pas vérifier le code de sortie quand, pour une raison ou une autre, le processus échoue. C'est un expédient dont on se servira seulement pour des programmes dont la duplication n'a pas de sens ou bien des programmes dont le code n'est pas transformable pour leur ajouter cette fonctionnalité. * **-N|--nicelevel** Cela modifie la priorité du processus avant qu'il ne soit lancé. * **-m | --make-pidfile** Est utilisé lors du lancement d'un programme qui ne crée pas son propre fichier identificateur. Cette option dit à start-stop-daemon de créer le fichier référencé par --pidfile et place le « pid » dans ce fichier juste avant d'exécuter le processus. Il faut remarquer que ce fichier n'est pas supprimé quand le programme s'arrête. NOTE : il se peut que cette caractéristique ne marche pas dans tous les cas. Et notamment quand le programme qui est exécuté se duplique. À cause de cela, cette option n'est habituellement utile que combinée avec l'option --background. * **-v | --verbose** Affiche des messages prolixes de renseignements. * **-H | --help** Affiche une aide et se termine. * **-V | --version** Affiche le numéro de version et se termine. ===== Exemples ===== Exemple de démarrage du démon ajaxterm : start-stop-daemon --start --pidfile $PIDFILE --exec $DAEMON -- --daemon --port=$PORT --uid=ajaxterm >/dev/null || return 2 Exemple d'arrêt du démon ajaxterm : start-stop-daemon --stop --pidfile $PIDFILE Exemple Apache : #! /bin/bash # # apache Start the apache HTTP server. # NAME=apache PATH=/bin:/usr/bin:/sbin:/usr/sbin DAEMON=/usr/sbin/apache SUEXEC=/usr/lib/apache/suexec PIDFILE=/var/run/$NAME.pid CONF=/etc/apache/httpd.conf APACHECTL=/usr/sbin/apachectl trap "" 1 export LANG=C export PATH test -f $DAEMON || exit 0 test -f $APACHECTL || exit 0 # ensure we don't leak environment vars into apachectl APACHECTL="env -i LANG=${LANG} PATH=${PATH} $APACHECTL" if egrep -q -i "^[[:space:]]*ServerType[[:space:]]+inet" $CONF then exit 0 fi case "$1" in start) echo -n "Starting web server: $NAME" start-stop-daemon --start --pidfile $PIDFILE --exec $DAEMON ;; stop) echo -n "Stopping web server: $NAME" start-stop-daemon --stop --pidfile $PIDFILE --oknodo --exec $DAEMON ;; reload) echo -n "Reloading $NAME configuration" start-stop-daemon --stop --pidfile $PIDFILE --signal USR1 --exec $DAEMON ;; reload-modules) echo -n "Reloading $NAME modules" start-stop-daemon --stop --pidfile $PIDFILE --oknodo --retry 30 start-stop-daemon --start --pidfile $PIDFILE --exec $DAEMON ;; restart) $0 reload-modules exit $? ;; force-reload) $0 reload-modules exit $? ;; *) echo "Usage: /etc/init.d/$NAME {start|stop|reload|reload-modules|force-reload|restart}" exit 1 ;; esac if [ $? == 0 ]; then echo . exit 0 else echo failed exit 1 fi