Docker中运行服务报错Failed to get D-Bus connection: Operation not permitted

Docker的设计理念是在容器里面不运行后台服务,容器本身就是宿主机上的一个独立的主进程,也可以间接的理解为就是容器里运行服务的应用进程。一个容器的生命周期是围绕这个主进程存在的,所以正确的使用容器方法是将里面的服务运行在前台。

再说到systemd,这个套件已经成为主流Linux发行版(比如CentOS7、Ubuntu14+)默认的服务管理,取代了传统的SystemV风格服务管理。systemd维护系统服务程序,它需要特权去会访问Linux内核。而容器并不是一个完整的操作系统,只有一个文件系统,而且默认启动只是普通用户这样的权限访问Linux内核,也就是没有特权,所以自然就用不了!

因此,请遵守容器设计原则,一个容器里运行一个前台服务!

解决方法: 运行增加 /usr/sbin/init就可以了

root@VM-236-5-ubuntu:~# docker run -d --name pxc1 --privileged=true centos /usr/sbin/init
 8720f7a5bf4c4d65fb8e78d018d71cd7cc370daf89bbdbdfc33eb764c99615f8
 root@VM-236-5-ubuntu:~# docker ps -a
 CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS               NAMES
 8720f7a5bf4c        centos              "/usr/sbin/init"    5 seconds ago       Up 4 seconds  
root@VM-236-5-ubuntu:~# docker exec -it 8720f7a5bf4c /bin/bash
[root@8720f7a5bf4c /]#  

发表评论

登录... 后才能评论