原文链接:http://blog.csdn.net/kongxx/article/details/38412119
已知默认启动容器内服务有两种方式
1、在启动容器的时候,后面跟上需要执行的脚本,例如:docker run -idt container_id /bin/start-service.sh
, ps:start-service.sh
为镜像内的脚本。
2、使用docker file
创建一个Dockerfile,内容如下
#选择一个已有的os镜像作为基础
FROM centos:centos6
#镜像的作者
MAINTAINER Fanbin Kong "kongxx@hotmail.com"
#安装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
#添加测试用户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"]
然后执行:docker build -t centos-ssh:1.0 .
,会创建一个新的镜像centos-ssh,tag为1.0,在创建容器时,后台会自动执行RUN和cmd的命令。