J'ai réussi à résoudre ce problème dans un conteneur Docker CentOS:7. J'ai suivi principalement le projet d'image Docker du Guide sur CentOS .
FROM centos:7
ENV container docker
RUN (cd /lib/systemd/system/sysinit.target.wants/; for i in *; do [ $i == \
systemd-tmpfiles-setup.service ] || rm -f $i; done); \
rm -f /lib/systemd/system/multi-user.target.wants/*;\
rm -f /etc/systemd/system/*.wants/*;\
rm -f /lib/systemd/system/local-fs.target.wants/*; \
rm -f /lib/systemd/system/sockets.target.wants/*udev*; \
rm -f /lib/systemd/system/sockets.target.wants/*initctl*; \
rm -f /lib/systemd/system/basic.target.wants/*;\
rm -f /lib/systemd/system/anaconda.target.wants/*;
# Install anything. The service you want to start must be a SystemD service.
CMD ["/usr/sbin/init"]
Maintenant, construisez l'image, et exécutez-la en utilisant au moins les arguments suivants pour docker run
commandement : -v /run -v /sys/fs/cgroup:/sys/fs/cgroup:ro
Ensuite, le point principal est que /usr/sbin/init
doit être le premier processus à l'intérieur du conteneur Docker.
Donc, si vous voulez utiliser un script personnalisé qui exécute certaines commandes avant d'exécuter /usr/sbin/init
lancez-le à la fin de votre script en utilisant exec /usr/sbin/init
(dans un script bash).
Voici un exemple :
ADD cmd.sh /usr/local/bin/
RUN chmod +x /usr/local/bin/cmd.sh
CMD ["/usr/local/bin/cmd.sh"]
Et voici le contenu de cmd.sh
:
#!/bin/bash
# Do some stuffs
exec /usr/sbin/init # To correctly start D-Bus thanks to https://forums.docker.com/t/any-simple-and-safe-way-to-start-services-on-centos7-systemd/5695/8
Vous auriez pu System is booting up. See pam_nologin(8)
si vous utilisez le système PAM, dans ce cas, supprimez /usr/lib/tmpfiles.d/systemd-nologin.conf
dans votre Dockerfile
car il crée le fichier /var/run/nologin
qui génère cette erreur spécifique.