#Base images FROM centos #MAINTAINER 维护人 MAINTAINER test #ADD 添加本地文件到镜像 ADD pcre-8.37.tar.gz /usr/local/src ADD nginx-1.9.3.tar.gz /usr/local/src #RUN 在镜像中执行命令 RUN yum install -y wget gcc_c++ make openssl-devel RUN useradd -s /sbin/nologin -M www #WORKDIR 镜像中切换到目录 WORKDIR /usr/local/src/nginx-1.9.3 RUN yum install -y gcc gcc-c++ RUN ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_ssl_module --with-http_stub_status_module --with-pcre=/usr/local/src/pcre-8.37 && make && make install RUN echo "daemon off;">>/usr/local/nginx/conf/nginx.conf #配置环境变量 ENV PATH /usr/local/nginx/sbin:$PATH EXPOSE 80 CMD ["nginx"]
了解了以上这些指令之后我们再来看Dockerfile做了哪些事情
1.指定了基础镜像Centos 2.指定了作者为test 3.这里我们看到了两个ADD命令,上面我们提到过ADD命令会自动解压原路径中的压缩文件,所有这两加过两个压缩文件解压到了指定目录。 4.安装 gcc_c++ make openssl-devel这几个软件 5.建立用户帐号和创建用户的起始目录,-s:指定用户登入后所使用的shell。默认值为/bin/bash。-M:不要自动建立用户的登入目录。 www为用户改名称。 6.设置了工作目录为:/usr/local/src/nginx-1.9.3 7.安装了gcc gcc-c++以及nginx,并将daemon off; 写入到nginx的config文件(daemon on | off 默认on:是否以守护进程的方式运行nginx,守护进程是指脱离终端并且在后头运行的进程,关闭守护进程执行的方式可以让我们方便调试nginx) 8.设置环境变量,将nginx sbin路径加入到了环境变量PATH中。 9.声明服务端口为80 10.设置了启动容器时,需要执行的命令。
编写万Dockerfile后我们就可以使用docker build命名制作镜像了,具体命令如下:
docker build -t nginx-image:v1 . -t指定了镜像的名称以及版本, 这个时候我们就制作了一个镜像, 名称为:nginx-docker
如果想要启动容器则执行命令:
docker run -it -p 8888:80 --name nginx-container nginx-image:v1
-t 选项让Docker分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上, -i 则让容器的标准输入保持打开, -p: 端口映射,格式为:主机(宿主)端口:容器端口, --name 指定了启动的容器的名称为nginx-container,方便以后识别。 这样我们就访问主机的8888端口,就可以访问到docker中运行的nginx 主页。
原文:https://www.cnblogs.com/is-possible/p/12323463.html