Dockerfile构建SSHD镜像

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

Dockerfile构建SSHD镜像_第1张图片

[root@docker ~]# systemctl restart network

[root@docker ~]# systemctl restart docker

3、导入基础镜像

[root@docker ~]# cat centos-7-x86_64.tar.gz | docker import - centos:7

Dockerfile构建SSHD镜像_第2张图片

4、建立工作目录

[root@docker ~]# mkdir sshd

[root@docker ~]# ssh-keygen

[root@docker ~]# cp .ssh/id_rsa.pub sshd/

[root@docker ~]# cd sshd

Dockerfile构建SSHD镜像_第3张图片

5、编写Dockerfile文件

[root@docker sshd]# ls

Dockerfile  id_rsa.pub

[root@docker sshd]# vim Dockerfile

#基于的基础镜像
FROM centos:7

#镜像作者信息
MAINTAINER Crushlinux 

#镜像执行的命令
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"]

Dockerfile构建SSHD镜像_第4张图片

6、构建镜像

[root@docker sshd]# docker build -t sshd:new .

[root@docker sshd]# docker images sshd:new

Dockerfile构建SSHD镜像_第5张图片

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 ~]#

Dockerfile构建SSHD镜像_第6张图片

 

你可能感兴趣的:(运维,学习,docker,容器)