1、很多兄弟在刚开始学习DOCKER时候,容易把docker的container和VM进行混淆,我也入了这样的坑。
在使用交互方式进入容器内部,执行systemctl之类的命令 ,发现会报错:
其实这是没有很好的理解docker:
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启动服务了。(个人不建议这么操作)
2、docker以容器进行运行,查阅很多文档,个人也觉得不适合用于DB这类的持续化存储,我觉得 如果非有必要性,可以将DB的中间件部署在容器中,而具体的DB进行卷挂载比较合适。