默认情况下 容器内不应该运行守护进程,若想使用则需要一些操作,详情如下:

run 启动参数上,加上 --privileged=true,然后,参数末尾 将 /bin/bash 替换为 /sbin/init (这是重点,由他启动一系列系统守护进程)

例如:

docker run -itd --name almalinux --privileged=true almalinux:8 /sbin/init

如果是通过 Dockerfile 构建的镜像,上述参数末尾的 /sbin/init 可以将其省略,并且写到 Dockerfile文件中,例如:

FROM almalinux:8

CMD ["/sbin/init"]

这样,镜像构建完成后,启动容器时,在 --privileged=true 参数的许可下,容器启动时,/sbin/init 将发挥它的作用,一系列系统服务将启动,前提是构建镜像时安装了他们,如 systemctl 等!

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐