docker基于Dockerfile命令创建支持ssh服务的镜像

首先,创建一个sshd_centos工作目录:

[[email protected] ~]# mkdir sshd_centos

[[email protected] ~]# cd sshd_centos

[[email protected] sshd_centos]# touch Dockerfile run.sh

[[email protected] sshd_centos]# ssh-keygen -t rsa

[[email protected] sshd_centos]# cat ~/.ssh/id_rsa.pub > authorized_keys

编写Dockfile文件

[[email protected] sshd_centos]# vim Dockerfile

#设置继承镜像

FROM docker.io/centos

#提供作者信息

MAINTAINER from xldwhj ([email protected])

#开始运行命令

RUN yum -y update

#安装openssh-serverfuwu

RUN yum -y install openssh-server

#修改/etc/ssh/sshd_config

RUN sed -i ‘s/UsePAM yes/UsePAM no/g‘ /etc/ssh/sshd_config

RUN mkdir -p /var/run/sshd

RUN mkdir -p /root/.ssh

RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key

RUN ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key

#复制配置文件到相应位置,并赋予脚本可执行权限

ADD authorized_keys /root/.ssh/authorized_keys

ADD run.sh /run.sh

RUN chmod 755 /run.sh

#变更root密码为123123

RUN echo "root:123123"|chpasswd

#开放22端口

EXPOSE 22

#运行脚本,启动sshd服务

CMD ["/run.sh"]

Dockerfile里的两条ssh-keygen要加上,如果不加ssh启动就会报如下错误。

在ssh_centos目录下,docker build命令来创建镜像。注意,此条命令后又一个“.”,代表当前目录中的Dockerfile。

[[email protected] sshd_centos]# docker build -t sshd:dockerfile .

执行到最后出现Successfully build XXX字样,则说明镜像创建成功。

[[email protected] sshd_centos]# docker images

使用sshd:dockerfile镜像运行一个容器。直接起动镜像

[[email protected] sshd_centos]# docker run -d -p 10222:22 sshd:dockerfile

[[email protected] .ssh]# ssh [email protected] -p 10022

如上所示,成功使用ssh登入到容器中。

时间: 2024-10-20 20:17:02

docker基于Dockerfile命令创建支持ssh服务的镜像的相关文章

创建支持SSH服务的镜像

一.基于commit命令创建 docker commit CONTAINER [REPOSITORY [:TAG]] 1.使用ubuntu镜像创建一个容器 docker run -it ubuntu /bin/bash 2.配置软件源 [email protected]:/# cp /etc/apt/sources.list /etc/apt/sources.list.bak [email protected]:/# apt-get update [email protected]:/# apt

Docker:使用Dockerfile创建支持SSH服务的镜像

1.创建工作目录 # mkdir sshd_ubuntu # ls 在其中,创建Dockerfile和run.sh文件 # cd sshd_ubuntu/ # touch Dockerfile run.sh # ls 2. 编写run.sh脚本和authorized_keys文件 # vi run.sh 写入内容: #! /bin/bash /usr/sbin/sshd –D 在宿主主机上生成SSH密钥对,并创建authorized_keys # ssh-keygen –t rsa # cat

Docker使用Dockerfile创建支持ssh服务自启动的容器镜像

1. 首先创建一个Dockerfile文件,文件内容如下 # 选择一个已有的os镜像作为基础 FROM centos:centos6 # 镜像的作者 MAINTAINER Fanbin Kong "[email protected]" # 安装openssh-server和sudo软件包,并且将sshd的UsePAM参数设置成no RUN yum install -y openssh-server sudo RUN sed -i 's/UsePAM yes/UsePAM no/g' /

创建支持ssh服务的docker容器和镜像

http://www.kongxx.info/blog/?p=57 1. 这里使用的centos作为容器,所以首先下载centos的imagessudo docker pull centos 2. 下载后运行一个centos的容器,这里使用centos6作为我测试的容器sudo docker run --name=centos-ssh -i -t centos:centos6 /bin/bash 3. 安装openssh-server服务软件包yum install openssh-server

用dockerfile创建支持ssh服务的centos镜像

参考 1 我在/docker/目录下建立了个脚本是用来启动容器上面的ssh服务的 vi run.sh #!/bin/bash /usr/sbin/sshd -D 2 同样在docker目录下创建dockefile文件如下: [[email protected] sbin]# cat /docker/dockerfile  FROM centos RUN yum install passwd openssl openssh-server -y ##下面三行是解决sshd服务启动时报错的 RUN s

Docker创建支持ssh服务的容器和镜像

Dockerfile 支持系统启动 运行ssh 服务 原文链接:http://blog.csdn.net/kongxx/article/details/38395305 # 选择一个已有的os镜像作为基础 FROM centos:centos6 # 镜像的作者 MAINTAINER Fanbin Kong "[email protected]" # 安装openssh-server和sudo软件包,并且将sshd的UsePAM参数设置成no RUN yum install -y ope

docker创建支持ssh服务的centos镜像

以centos为基础,目的使用ssh服务远程连接docker容器 环境:宿主机centos7,直接搜索docker的centos镜像,下载最新版本 1.先按照docker:yum install -y epel-release yum install -y docker 2.启动docker: systemctl start docker.service 3.使用ps查看docker是否启动 ps aux |grep docker 4.下载centos的docker镜像 docker pull

Docker-创建支持ssh服务的镜像

这里测试tomcat镜像安装ssh服务 1.启动镜像 [[email protected] docker]$ docker run -d tomcat:centos 844bdde121a03174f3abd226a9ef286938b6ea4a1fbd2659961b1e8542ca3ccd [[email protected] docker]$ docker exec -it 844 /bin/bash [[email protected] /]# 2.安装ssh服务 [[email pro

通过Dockerfile创建支持SSH服务的docker镜像(centos、Ubuntu)

centos: mkdir centos-ssh vim centos-ssh/Dockerfile FROM centos MAINTAINER blog.rootr.cn [email protected] RUN yum install -y openssh-server RUN mkdir /var/run/sshd RUN ssh-keygen -q -t rsa -b 2048 -f /etc/ssh/ssh_host_rsa_key -N '' && \ ssh-keygen