原文连接:http://blog.csdn.net/kongxx/article/details/38412119
docker
已知默认启动容器内服务有两种方式
一、在启动容器的时候,后面跟上须要执行的脚本,例如:docker run -idt container_id /bin/start-service.sh
, ps:start-service.sh
为镜像内的脚本。
二、使用docker filecentos
建立一个Dockerfile,内容以下ssh
#选择一个已有的os镜像做为基础
FROM centos:centos6
测试
#镜像的做者
MAINTAINER Fanbin Kong "kongxx@hotmail.com"
ui
#安装openssh-server和sudo软件包,而且将sshd的UsePAM参数设置成no
RUN yum install -y openssh-server sudo
RUN sed -i 's/UsePAM yes/UsePAM no/g' /etc/ssh/sshd_config
.net
#添加测试用户admin,密码admin,而且将此用户添加到sudoers里
RUN useradd admin
RUN echo "admin:admin" | chpasswd
RUN echo "admin ALL=(ALL) ALL" >> /etc/sudoers
code
#下面这两句比较特殊,在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
server
#启动sshd服务而且暴露22端口
RUN mkdir /var/run/sshd
EXPOSE 22
CMD ["/usr/sbin/sshd", "-D"]
blog
而后执行:docker build -t centos-ssh:1.0 .
,会建立一个新的镜像centos-ssh,tag为1.0,在建立容器时,后台会自动执行RUN和cmd的命令。cmd