Docker虚拟化技术系列之-DockerFile案例演练
Dockfile是一种被Docker程序能够解释的脚本,Dockerfile由一条一条的指令组成,每条指令对应Linux下面的一条命令。Docker程序将这些Dockerfile指令翻译真正的Linux命令。Dockerfile有自己书写格式和支持的命令,Docker程序解决这些命令间的依赖关系,类似于Makefile。Docker程序将读取Dockerfile,根据指令生成定制的image。相比镜像这种黑盒子,Dockerfile这种显而易见的脚本更容易被使用者接受,它明确的表明镜像是怎么产生的。有了Dockerfile,我们需要定制自己额外的需求时,只需在Dockerfile上添加或者修改指令,重新生成镜像即可。给大家分享几个常用的案例,DockerFile企业案例实战,开放80端口和22端口配置案例:1)开启SSH 22端口,并远程连接服务器,dockerfile内容如下:# 设置基本的镜像,后续命令都以这个镜像为基础FROM centos_lamp:v1 # 作者信息MAINTAINER JFEDU.NET# RUN命令会在上面指定的镜像里执行任何命令RUN yum install passwd openssl openssh-server -yRUN echo '123456' | passwd --stdin rootRUN sed -i'/^session\s\+required\s\+pam_loginuid.so/s/^/#/' /etc/pam.d/sshdRUN mkdir -p /root/.ssh && chown root.root /root&& chmod 700 /root/.sshRUN mkdir /var/run/sshd#暴露ssh端口22EXPOSE22#设定运行以daemon方式启动sshdCMD /usr/sbin/sshd -D2)开启Apache 80端口,并远程连接服务器,dockerfile内容如下:# 设置基本的镜像,后续命令都以这个镜像为基础FROM centos_lamp:v1# 作者信息MAINTAINER JFEDU.NET# RUN命令会在上面指定的镜像里执行任何命令RUN yum install pcre-devel -yRUN yum install httpd httpd-devel -y#暴露ssh端口80EXPOSE 80#启动httpdCMD ["/usr/sbin/apachectl", "-D","FOREGROUND"]最终截图如下:到此结束了吗?远远没有哦,思考一个问题,如何同时开放多个端口呢,例如80、22、8080、3306端口对外访问呢?
页:
[1]