J'écris un script shell que j'aimerais exécuter en tant que démon au démarrage sans utiliser d'outils externes comme daemontools ou daemonize .
Linux Daemon Writing HOWTO
Selon le Linux Daemon Writing HOWTO , un démon approprié a les caractéristiques suivantes:
- fourches du processus parent
- ferme tous les descripteurs de fichiers ( par exemple,
stdin
,stdout
,stderr
) - ouvre les journaux pour l'écriture (si configuré)
- change le répertoire de travail en un répertoire persistant (généralement
/
) - réinitialise le masque du mode fichier (umask)
- crée un identifiant de session unique (SID)
Présentation de daemonize
L' introduction de daemonize va plus loin, déclarant qu'un démon typique aussi:
- se dissocie de son terminal de commande (s'il y en a un) et ignore tous les signaux du terminal
- se dissocie de son groupe de processus
- poignées
SIGCLD
Comment puis-je faire tout cela dans un sh
, dash
ou bash
script avec des outils Linux communs seulement?
Le script devrait pouvoir fonctionner sur autant de distributions que possible sans logiciel supplémentaire, bien que Debian soit notre objectif principal.
REMARQUE: Je sais qu'il existe de nombreuses réponses sur le réseau StackExchange recommandant l'utilisation de nohup
ou setsid
, mais aucune de ces méthodes ne répond à toutes les exigences ci-dessus.
EDIT: La page de manuel daemon (7) donne également quelques pointeurs, bien qu'il semble y avoir des différences entre les SysV
démons de style ancien et les plus systemd
récents. Étant donné que la compatibilité avec une variété de distributions est importante, veuillez vous assurer que la réponse indique clairement toute différence.
la source
daemon
et les autres sont pour l' exécution arbitraire des scripts shell avec aucune disposition pour l' exécution en un démon. Puisque vous êtes l'auteur et que vous contrôlez entièrement la façon dont ce script est écrit, faites en sorte qu'il puisse simplement être lancé à partir d'un fichier unitaire systemd ou d'un script rc.d. Vous avez spécifié « approprié »!Réponses:
En utilisant systemd, vous devriez pouvoir exécuter un script en tant que démon en créant une unité simple. Il existe de nombreuses options différentes que vous pouvez ajouter, mais c'est aussi simple que possible.
Disons que vous avez un script
/usr/bin/mydaemon
.Vous créez une unité
/etc/systemd/system/mydaemon.service
.Pour démarrer le démon que vous exécutez
Pour démarrer au démarrage, vous l'activez
Si sur un système basé sur systemd, ce que la majorité des distributions Linux sont aujourd'hui, ce n'est pas vraiment un outil externe. Le négatif serait que cela ne fonctionnera pas partout cependant.
la source
systemd
n'est pas plus un "outil externe" quebash
.Il me manque probablement quelque chose ici; pourquoi ne serait-il pas
nohup
approprié? Bien sûr, cela ne suffit pas seul , mais le compléter semble simple.D'aussi loin que je puisse voir:
stdin
meurt à la fin du script parent cependantinit
(ousystemd
)J'ai le sentiment fort que je manque l'évidence. Downvote, mais dites-moi ce que c'est :-)
la source
nohup
avec&
et la redirection d'E / S pour lancer plusieursC
utilitaires non- démon avec peut-être la sécurité supplémentaire d'envelopper votrenohup
commande à l'intérieur d'unsu -c "nohup ... &" -s /bin/bash systemUser
pour exécuter le démon en tant qu'utilisateur non privilégié.La
screen
commande Linux contenue dans la plupart des distributions peut démonifier un script shell. Je l'utilise souvent. Voici un exemple rapide pour démarrer, répertorier et quitter une session d'écran détachée ...la source
screen
ne désamorce pas le script shell. Il suffit de les exécuter dans un terminal distingué et peut se détacher de ce terminal (comme débrancher le clavier du PC) sans fermer la session. Ainsi, le programme s'exécutant dans un terminal détaché s'exécute en arrière-plan. Par conséquent, détachez le programme de passe en arrière-plan.