Docker容器中使用systemctl 的方法

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

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 等!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值