用Dockerfile配置SSH远端登陆ubuntu

文件目录结构:

用Dockerfile配置SSH远端登陆ubuntu_第1张图片

(1).authorized_keys(rsa秘钥)文件由mac 终端生成

用Dockerfile配置SSH远端登陆ubuntu_第2张图片

(2).run.sh 启动ssh服务的shell脚本文件

#!/bin/bash
/usr/sbin/sshd -D

第一行代表指令运行需要的环境

Dockerfile代码:

FROM ubuntu
MAINTAINER “niwanglongSshUbuntu”
#apt-get 换源
RUN sed -i 's/archive.ubuntu.com/mirrors.ustc.edu.cn/g' /etc/apt/sources.list
RUN apt-get update

#安装SSH服务
RUN apt-get install -y openssh-server
RUN mkdir -p /var/run/sshd
RUN mkdir -p /root/.ssh

#配置SSH
#设置ssh远程登陆密码
RUN echo "root:123456" | chpasswd
RUN sed -ri 's/^PermitRootLogin\s+.*/PermitRootLogin yes/' /etc/ssh/sshd_config  
RUN sed -ri 's/UsePAM yes/#UsePAM yes/g' /etc/ssh/sshd_config  

#复制Rsa文件到相应位置,并赋予脚本可执行权限
ADD authorized_keys /root/.ssh/authorized_keys
ADD run.sh /run.sh
RUN chmod 755 /run.sh

#开放端口
EXPOSE 22

#设置自启动命令
CMD ["/bin/bash","/run.sh"]

dokcer build 后,运行容器即可。不懂的可以看下我宁外一篇文章,Docker 配置前端开发环境实战

用Dockerfile配置SSH远端登陆ubuntu_第3张图片
Paste_Image.png

在mac下输入dockerfile 设置的root密码即可登录了。

遇到的问题


1.提示远端rsa秘钥已改变

删除/users/yixinmac/.ssh目录下的文件,然后重新生成rsa秘钥,再build新的配置镜像,当然你也可以进入容器替换掉/root/.ssh/authorized_keys目录下的秘钥文件再重启ssh服务即可。这里得力于docker的联合文件系统,旧镜像存在的情况下,我们可以快速的再新建新的镜像。
docker build -t registry:tag .走起

你可能感兴趣的:(用Dockerfile配置SSH远端登陆ubuntu)