Ceci est une ancienne révision du document !
Table des matières
Notes PID1 conteneurs
Généralités
Voir :
Something like dumb-init or tini can be used if you have a process that spawns new processes and you don't have good signal handlers implemented to catch child signals and stop your child if your process should be stopped etc.
If your process doesn't spawn new processes (e.g. Node.js), then this may not be necessary.
I guess that MongoDB, PostgreSQL, … which may run child processes have good signal handlers implemented. Otherwise there would have been zombie processes and someone would have filed an issue to fix this.
Only problem may be the official language images, like node, ruby, golang. They don't have dumb-init/tini in it as you normally don't need them. But it's up to the developer which may implement bad child execution code to either fix the signal handlers or use helper as PID 1.
Source : https://stackoverflow.com/questions/37374310/how-critical-is-dumb-init-for-docker
Sans gestion de services
- runit (fonctionnalités de base incluse dans Busybox) https://wiki.archlinux.org/title/Runit
- SystemD
- S6
Avec gestion de services
- tini / dumb-init / catatonit
- pid1 (paquet pid1) https://github.com/fpco/pid1
