# 拷贝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