转载自:https://blog.csdn.net/zhenliang8/article/details/78330658

最近使用docker部署ansible,安装ssh 遇到启动服务报错:Failed to get D-Bus connection: Operation not permitted

刚开始接触Docker的朋友,可能会遇到这么一个问题,使用centos7镜像创建容器后,在里面使用systemctl启动服务报错。针对这个报错,我们接下来就分析下!

# docker run -itd --name centos7 centos:7

# docker attach centos7

# yum install vsftpd

# systemctl start vsftpd

Failed to get D-Bus connection: Operation not permitted

不能启动服务,什么情况?

难道容器不能运行服务嘛!!!

答:

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

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

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

我就想这样运行,难道解决不了吗?

答:可以,以特权模式运行容器。

创建容器:

# docker run -d -name centos7 --privileged=true centos:7 /usr/sbin/init

进入容器:

# docker exec -it centos7 /bin/bash

这样可以使用systemctl启动服务了。

最新文章

  1. POJ3259Wormholes(判断是否存在负回路)
  2. Laravel 5 基础(九)- 表单
  3. WinCE5.0中文模拟器SDK(VS2005)的配置
  4. 深入学习APC
  5. Contest20140705 testB DP
  6. C++中引用
  7. C++内存中的封装、继承、多态(上)
  8. We Talk -- 团队博客
  9. js生成四位随机数的简便方法
  10. LeetCode(31)-Factorial Trailing Zeroes
  11. [Swift]LeetCode1009. 十进制整数的补码 | Complement of Base 10 Integer
  12. Go之unsafe.Pointer && uintptr 类型
  13. China’s movie heroes 《红海行动》展现中国英雄本色
  14. Java反射《三》获取属性
  15. poj 2438 Children's Dining
  16. 使用docker来部署asp.net core的程序
  17. Python3.5 学习十一
  18. Dynamics 365 可编辑子网格的字段禁用不可编辑
  19. SpringBoot项目中加入jsp页面
  20. 2017-2018-2 20172323 『Java程序设计』课程 结对编程练习_四则运算

热门文章

  1. webserver 简单demo
  2. 基于Docker部署Dubbo+Nacos服务
  3. 在 WXML 中使用 JS 代码
  4. StatefulWidget 组件的参数时(widget.xxx)报 Invalid Constant Value
  5. IP 地址分类及子网划分
  6. Postgresql 二进制字符串函数和操作符
  7. Solon2 的应用生命周期
  8. gunicorn的功能及使用方法
  9. pytest框架插件源码_关于钩子方法调用部分的简单理解(pytest_runtest_makereport)
  10. Nacos安装与启动