一、sshd的镜像创建
首先进到/opt目录下
mkdir sshd ##创建一个目录存放文件和软件包
cd sshd
vim Dockerfile ##写Dockerfile文件
FROM centos:7
MAINTAINER the centos project
RUN yum -y update
RUN yum -y install net-tools lsof openssh* telnet passwd
RUN echo "123456" | passwd --stdin root
RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config
RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key
RUN sed -i '/^session\s\+required\s\+pam_loginuid.so/s/^/#/' /etc/pam.d/sshd
RUN mkdir -p /root/.ssh && chown root:root /root && chmod 700 /root/.ssh
EXPOSE 22
CMD ["/usr/sbin/sshd","-D"]
docker build -t sshd:new . ##生成镜像
docker run -d -P sshd:new ##运行容器
docker ps -a
ssh localhost -p 32770 ##宿主机登录sshd容器
二、systemctl镜像创建
同样在opt目录下创建一个systemctl文件夹存放
mkdir systemctl
cd systemctl
vim Dockerfile
FROM sshd:new ##基于sshd的镜像基础创建systemctl镜像
ENV container docker
RUN (cd /lib/systemd/system/sysinit.target.wants/;for i in *; \
do [ $i == systemd-tmpfiles-setup.service ] || rm -f $i;done); \
rm -f /lib/systemd/system/multi-user.target.wants/*; \
rm -f /etc/systemd/system/*.wants/*; \
rm -f /lib/systemd/system/local-fs.target.wants/*; \
rm -f /lib/systemd/system/sockets.target.wants/*udev*