Dockerfile构建SSHD镜像
基于Dockerfile制作镜像时首先需要建立工作目录,作为生成镜像的工作目录,然后分别创建并编写 Dockerfile文件、需要运行的脚本文件以及要复制到容器中的文件。
1、环境配置:
[root@docker ~]# iptables -F
[root@docker ~]# setenforce 0
[root@docker ~]# systemctl stop firewalld
2、关注DNS地址:
[root@docker ~]# cat /etc/resolv.conf
[root@docker ~]# vim
/etc/sysconfig/network-scripts/ifcfg-ens33
DNS1=8.8.8.8
[root@docker ~]# systemctl restart network
[root@docker ~]# systemctl restart docker
3、导入基础镜像:
[root@docker ~]# cat centos-7-x86_64.tar.gz | docker import - centos:7
4、建立工作目录
[root@docker ~]# mkdir sshd
[root@docker ~]# ssh-keygen
[root@docker ~]# cp .ssh/id_rsa.pub sshd/
[root@docker ~]# cd sshd
5、编写Dockerfile文件
[root@docker sshd]# ls
Dockerfile id_rsa.pub
[root@docker sshd]# vim Dockerfile
#基于的基础镜像
FROM centos:7
#镜像作者信息
MAINTAINER Crushlinux <crushlinux@163.com>
#镜像执行的命令
RUN yum -y install openssh-server net-tools openssh-devel lsof telnet
RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config
RUN ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key
RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key
ADD id_rsa.pub /root/.ssh/authorized_keys
#定义时区
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
#开启 22 端口
EXPOSE 22
#启动容器时执行指令
CMD ["/usr/sbin/sshd" , "-D"]
6、构建镜像
[root@docker sshd]# docker build -t sshd:new .
[root@docker sshd]# docker images sshd:new
7、测试容器
[root@docker sshd]# docker run -d -p 2222:22 --name sshd-test --restart=always sshd:new
[root@docker sshd]# ssh localhost -p 2222
The authenticity of host '[localhost]:2222
[root@89c847ca1333 ~]#