赞
踩
即使是开了特权模式(--privileged
)
/sbin/init
启动容器要想在容器中使用systemctl
命令,除了要指定--privileged
参数外,还需要指定启动参数为/sbin/init
,但是大多数系统会有以下问题。
目前大部分的系统镜像,移除了init软件包,导致镜像中没有/sbin/init
文件,从而导致无法启动。
通过Dockerfile
文件修改镜像,达到使用systemctl
的目的
Dockerfile
文件如下:
debian
系:
FROM ubuntu
RUN apt-get update && apt-get install -y init && apt-get clean all
ENTRYPOINT ["/sbin/init"]
redhat
系:
FROM openeuler/openeuler
RUN yum update -y && yum install systemd -y
ENTRYPOINT ["/sbin/init"]
两者的区别在于安装的软件包名不同,debian
系的软件包名为init
,而redhat
系则是systemd
,实际使用时,将源镜像换成所需镜像即可
docker build -t 新镜像名称:tag名称 .
docker run -itd --privileged new_ubuntu:latest /sbin/init
进入对应的容器中,就可以执行相关命令了,即拥有了特权模式
开启特权模式纵然方便,但是可能存在一定的风险,容器获得特权模式时,将能够访问宿主机所有资源,从而导致各种安全问题。本教程之所以如此,是将docker容器作为虚拟机使用。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。