-
首先从dock hub 下载 ubuntu的镜像
命令: docker pull ubuntu
-
新建一个ssh_ubuntu 目录
mkdir /ssh_ubuntu
-
cd /ssh_ubuntu ;touch Dockerfile
-
vi Dockerfile
Dockerfile内容
FROM ubuntu
MAINTAINER lincoln_zhong
RUN apt-get update
RUN apt-get install -y openssh-server sudo
RUN mkdir -p /var/run/sshd
RUN sed -ri 's/session required pam_loginuid.so/#session required pam_loginuid.so/g' /etc/pam.d/sshd
RUN useradd admin
RUN echo "admin:admin" | chpasswd
RUN echo "admin ALL=(ALL) ALL" >> /etc/sudoers
EXPOSE 22
CMD ["/usr/sbin/sshd" , "-D"]
-
cd /ssh_ubuntu .运行 docker build -t ssh_ubuntu . #ssh_ubuntu是镜像名称
-
运行 docker images
-
运行一个容器测试 命令: docker run -d --name ssh_ubuntu_test -p 0.0.0.0:10000:22 ssh_ubuntu
命令解析
-d是以守护模式启动
--name 定义容器名称
-p是定义端口(上面这个意思是本地主机(宿主机)的10000端口映射到容器的22端口
-
容器ssh_ubuntu_test 运行成功, 用ssh登入容器测试命令: ssh admin@宿主机IP -p 10000 我这里是10.10.1.181
ssh admin@10.10.1.181 -p 10000
-
测试成功
-
附centos搭建支持ssh的容器dockerfile 内容
-
# 选择一个已有的os镜像作为基础
FROM centos -
# 镜像的作者
MAINTAINER LINCOLN ZHONG
# 安装openssh-server和sudo软件包,并且将sshd的UsePAM参数设置成no
RUN yum install -y openssh-server sudo
RUN sed -ir 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config
# 添加测试用户admin,密码admin,并且将此用户添加到sudoers里
RUN useradd admin
RUN echo "admin:admin" | chpasswd
RUN echo "admin 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"]
本文出自 “昨夜雨疏风骤” 博客,请务必保留此出处http://zxx287856774.blog.51cto.com/3417296/1664682