Dockerfile构建SSHD镜像

本文详细介绍了如何基于Dockerfile在CentOS系统上构建一个支持SSH服务的镜像,包括环境配置、DNS设置、基础镜像导入、Dockerfile编写及镜像构建和测试过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云隐智者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值