爱在莫斯科 发表于 2018-5-30 07:59:04

创建支持ssh的docker镜像

  docker容器运行,一般不能ssh,这容器的管理带来麻烦,下面将介绍如何创建支持ssh的docker镜像

[*]  首先从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"]
  

页: [1]
查看完整版本: 创建支持ssh的docker镜像