1.创建容器
docker run -d -p 22222:22 --name centos --privileged=true centos:7 /usr/sbin/init
这里不能直接打开交互模式,会卡住
2.进入容器
docker exec -it centos /bin/bash
3.安装ssh
yum -y install openssh*
4.开起服务
systemctl start sshd //开起ssh服务
systemctl list-units|grep ssh //查看服务
5.添加用户
useradd test
passwd test
6.添加用户权限
yum -y install sudo
7.更改
/etc/sudoers
juan ALL =(ALL)ALL
参考文献:
https://blog.csdn.net/zhenliang8/article/details/78330658
Docker的设计理念是在容器里面不运行后台服务,容器本身就是宿主机上的一个独立的主进程,也可以间接的理解为就是容器里运行服务的应用进程。一个容器的生命周期是围绕这个主进程存在的,所以正确的使用容器方法是将里面的服务运行在前台。
再说到systemd,这个套件已经成为主流Linux发行版(比如CentOS7、Ubuntu14+)默认的服务管理,取代了传统的SystemV风格服务管理。systemd维护系统服务程序,它需要特权去会访问Linux内核。而容器并不是一个完整的操作系统,只有一个文件系统,而且默认启动只是普通用户这样的权限访问Linux内核,也就是没有特权,所以自然就用不了!
因此,请遵守容器设计原则,一个容器里运行一个前台服务!
我就想这样运行,难道解决不了吗?
答:可以,以特权模式运行容器。