通过dockerfile来制作ssh镜像

新建一个文件夹

mkdir -p /opt/ubuntu-ssh-root

# 将宿主机的/etc/apt/sources.list文件拷贝到该目录下
cp /etc/apt/sources.list /opt/ubuntu-ssh-root

 

银河麒麟 arm架构 ubuntu docker制作ssh镜像

 

 

编写Dockerfile文件

vim Dockerfile

内容如下:

# 选择一个已有的os镜像作为基础  
FROM aarch64/ubuntu:16.04

# 镜像的作者  
MAINTAINER hanzhe

# 拷贝sources.list文件到/etc/apt下,后续安装服务需要 COPY sources.list
/etc/apt/ # 安装openssh-server和sudo软件包,并且将sshd的UsePAM参数设置成no # 尽量少些RUN命令,而改用&& 减少封装次数
# 更新镜像源 RUN apt update \
&& apt install -y openssh-server \ && sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config \ #安装openssh-clients && apt install -y openssh-client \
# 这个地方需要注意,可能配置不一样,根据个人的实际配置文件来进行修改
&& sed -i 's/PermitRootLogin prohibit-password/PermitRootLogin yes/' /etc/ssh/sshd_config \ # 添加测试用户root,密码root,并且将此用户添加到sudoers里 && echo root:root | chpasswd \ && echo "root ALL=(ALL) ALL" >> /etc/sudoers # 下面这两句比较特殊,在centos6上必须要有,否则创建出来的容器sshd不能登录 #RUN ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key #RUN ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key # 启动sshd服务并且暴露22端口 RUN mkdir /var/run/sshd EXPOSE 22 CMD ["/usr/sbin/sshd", "-D"]

 

通过Dockerfile来构建docker image

docker build -t="ubuntu-ssh-root" .

 

查看docker images

docker images

银河麒麟 arm架构 ubuntu docker制作ssh镜像

 

 

启动docker 容器

docker run -it -d --name test ubuntu-ssh-root:latest

 

进入容器,进行测试成功