docker 镜像支持systemctl的方法

本文介绍了在Dockerfile中使用systemctl启动服务遇到的问题,提供了两种解决方案:一是提升权限执行,二是基于centos/systemd基础镜像。详细步骤包括创建镜像、配置nginx、empire和CMS,以及正确的docker运行命令和注意事项。

一般制作docker镜像的时候,在Dockerfile里面运行systemctl start命令,系统是不支持的.我们提供二种支持方法.目前centos7作为基础镜像是支持的

通过提升权限

1) 如下制作一个镜像,并准备好nginx.conf,empire.conf,和cms.tar.gz

FROM centos:7
WORKDIR /opt
ADD cms.tar.gz .
RUN yum -y install epel-release ;yum -y install nginx mariadb-server php-fpm; yum clean all; systemctl enable httpd.service ; \
    systemctl enable php-fpm;systemctl enable mariadb;
COPY nginx.conf /etc/nginx;
COPY empire.conf /etc/nginx/conf.d
RUN ln -s /opt/cms /usr/share/nginx/html/cms
EXPOSE 80
CMD ["/usr/sbin/init"]

2)编译并执行

docker build . -t local/empire

3)执行,注意把防火墙关闭,测试应成功.如果不成功,docker ps -a 看看是不是docker没启动成功,并排错.

docker run -it -d --name ecms --cap-add SYS_ADMIN -p 80:80  --privileged local/empire

直接使用centos/systemd 做基础镜像
1)制作dockerfile

FROM centos/systemd
WORKDIR /opt
ADD cms.tar.gz .
RUN yum -y install epel-release ;yum -y install nginx mariadb-server php-fpm; yum clean all; systemctl enable httpd.service ; \
    systemctl enable php-fpm;systemctl enable mariadb;
COPY nginx.conf /etc/nginx;
COPY empire.conf /etc/nginx/conf.d
RUN ln -s /opt/cms /usr/share/nginx/html/cms
EXPOSE 80
CMD ["/usr/sbin/init"]

2) 正常执行

docker run -it -d --name ecms -p 80:80 local/empire

 

### 在Docker容器中安装和配置 `systemctl` 为了在基于CentOS或其他支持Systemd的Linux发行版的Docker容器内使用`systemctl`,需要执行特定的操作来启用Systemd支持。默认情况下,大多数官方基础镜像并不包含完整的init系统。 #### 启用 Systemd 支持 对于某些版本的基础镜像,可以通过指定带有Systemd支持的变体来简化此过程。例如,在构建阶段可以选择一个已经预装了Systemd组件的镜像: ```dockerfile FROM centos/systemd:latest ``` 然而,当目标是在运行中的容器内部激活`systemctl`功能时,则需采取额外措施[^1]。 #### 修改 Docker 守护程序配置 为了让容器能够正常启动并维持Systemd服务的状态,必须调整宿主机上的Docker守护程序设置。编辑 `/etc/docker/daemon.json` 文件加入如下参数: ```json { "exec-opts": ["native.cgroupdriver=systemd"], "log-driver": "journald", "storage-driver": "overlay2" } ``` 重启Docker服务使更改生效之后,创建新的容器实例之前还需确保传递恰当的选项给`docker run`命令,比如分配更多的资源限额以及必要的特权模式开关: ```bash docker run \ --privileged \ --tmpfs /run \ --tmpfs /run/lock \ -v /sys/fs/cgroup:/sys/fs/cgroup:ro \ ... ``` 这些操作允许容器内的进程管理工具(如`systemctl`)正确地与cgroups交互,并保持持久化的日志记录能力。 #### 配置容器环境 进入已准备好的容器环境中后,可以继续按照常规流程完成剩余的服务部署工作。此时应该可以直接调用`systemctl`指令来进行服务控制而不必担心缺少依赖项的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老骥又出发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值