Docker (五) 利用Dockerfile创建Nginx镜像

版本一

第一步:下载基础镜像

本实例是基于centos7镜像进行操作的,所以需要下载docker的centos7镜像

官方镜像连接:https://hub.docker.com/search?q=&type=image

[root@wallace ~] docker pull centos:centos7

第二步:创建一个测试目录,用来保存该项目所需要的所有文件信息

[root@wallace ~]# mkdir myNginx
[root@wallace ~]# cd myNginx/
[root@wallace mydocker]# touch Dockerfile
[root@wallace mydocker]# ll
总用量
0 -rw-r--r-- 1 root root 0 1月 10 17:34 Dockerfile

第三步:编写Dockerfile

FROM centos:centos7

MAINTAINER wallace@163.com
# 安装一些常用工具包
RUN yum install make wget bzip2 -y
# 加载一下阿里的镜像源,方便下载编译的包
RUN mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

RUN wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
# 安装依赖包
RUN yum install automake gcc gcc-c++ autoconf zlib-devel openssl openssl-devel pcre* pcre-devel zlib -y

# 复制包到docker容器
COPY nginx-1.8.0.tar.gz /opt/nginx/
COPY pcre-8.37.tar.bz2 /opt/pcre/

RUN tar xf /opt/pcre/pcre-8.37.tar.bz2 -C /usr/local/src/

RUN tar -xvzf /opt/nginx/nginx-1.8.0.tar.gz -C /usr/local/src/ 
    && useradd -M -s /sbin/nologin nginx

WORKDIR /usr/local/src/nginx-1.8.0
# 编译安装
RUN ./configure 
--prefix=/usr/local/nginx
--with-http_dav_module
--with-http_stub_status_module
--with-http_addition_module
--with-http_sub_module
--with-http_flv_module
--with-http_mp4_module
--with-pcre=/usr/local/src/pcre-8.37 && make –j 3 ; make install ; cd ENV PATH=/usr/local/nginx/sbin:$PATH EXPOSE 80

第四步:执行创建

[root@server mydocker]# ll
总用量 4
-rw-r--r-- 1 root root 1268 1月  10 17:40 Dockerfile
[root@server mydocker]# docker build -t centos_nginx:v1 . 

第五步: 创建docker容器

[root@wallace mydocker]# docker run -d -p 80:80 mynginx:v1 nginx -g "daemon off;"
7caa6019653f92db0e85f511aed29f3a56529321e08f08811658758a705f29b4
[root@wallace mydocker]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                NAMES
7caa6019653f        mynginx:v1          "nginx -g 'daemon of…"   5 seconds ago       Up 3 seconds        0.0.0.0:80->80/tcp   vigorous_khorana

第六步: 登入网页测试

版本二: 添加CMD指令的方式

第一步: 编写文件,在之前基础上添加CMD指令

FROM centos:centos7

MAINTAINER wallace@163.com


RUN yum install make wget bzip2 -y

RUN mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

RUN wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo

RUN yum install automake gcc gcc-c++ autoconf zlib-devel openssl openssl-devel pcre* pcre-devel zlib -y


COPY nginx-1.8.0.tar.gz /opt/nginx/
COPY pcre-8.37.tar.bz2 /opt/pcre/

RUN tar xf /opt/pcre/pcre-8.37.tar.bz2 -C /usr/local/src/

RUN tar -xvzf /opt/nginx/nginx-1.8.0.tar.gz -C /usr/local/src/ 
    && useradd -M -s /sbin/nologin nginx

WORKDIR /usr/local/src/nginx-1.8.0

RUN ./configure --prefix=/usr/local/nginx 
--with-http_dav_module
--with-http_stub_status_module
--with-http_addition_module
--with-http_sub_module
--with-http_flv_module
--with-http_mp4_module
--with-pcre=/usr/local/src/pcre-8.37 && make –j 3 ; make install ; cd ENV PATH=/usr/local/nginx/sbin:$PATH EXPOSE 80 # 比之前多一行启动命令,注意是前台启动 CMD /bin/sh -c 'nginx -g "daemon off;"'

新增加的CMD /bin/sh -c 'nginx -g "daemon off;"' 表示

当启动一个容器时候默认运行的命令,如果在启动容器时赋予了command的话,那么定义的CMD中的命令将不会被执行,而会去执行command的命令

第二部: 构建镜像

[root@wallace mydocker]# docker build -t mynginx:v2 .
Sending build context to Docker daemon  2.394MB
Step 1/15 : FROM centos:centos7
 ---> 7e6257c9f8d8
Step 2/15 : MAINTAINER wallace@163.com
 ---> Using cache
 ---> acc7f716a143
Step 3/15 : RUN yum install make wget bzip2 -y
 ---> Using cache
 ---> e63c027f7961
Step 4/15 : RUN mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak
 ---> Using cache
 ---> fe16788aee95
Step 5/15 : RUN wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
 ---> Using cache
 ---> 99892504975c
Step 6/15 : RUN yum install automake gcc gcc-c++ autoconf zlib-devel openssl openssl-devel pcre* pcre-devel zlib -y
 ---> Using cache
 ---> 55a4588aa407
Step 7/15 : COPY nginx-1.8.0.tar.gz /opt/nginx/
 ---> Using cache
 ---> e69eab8dd722
Step 8/15 : COPY pcre-8.37.tar.bz2 /opt/pcre/
 ---> Using cache
 ---> 671eb0829d88
Step 9/15 : RUN tar xf /opt/pcre/pcre-8.37.tar.bz2 -C /usr/local/src/
 ---> Using cache
 ---> 5e32435598c7
Step 10/15 : RUN tar -xvzf /opt/nginx/nginx-1.8.0.tar.gz -C /usr/local/src/     && useradd -M -s /sbin/nologin nginx
 ---> Using cache
 ---> 859c0fc26b64
Step 11/15 : WORKDIR /usr/local/src/nginx-1.8.0
 ---> Using cache
 ---> ebfbec88bba0
Step 12/15 : RUN ./configure --prefix=/usr/local/nginx --with-http_dav_module --with-http_stub_status_module --with-http_addition_module --with-http_sub_module --with-http_flv_module --with-http_mp4_module --with-pcre=/usr/local/src/pcre-8.37 && make –j 3 ; make install ; cd
 ---> Using cache
 ---> 3229dbf0ae6a
Step 13/15 : ENV PATH=/usr/local/nginx/sbin:$PATH
 ---> Using cache
 ---> 74bf35748279
Step 14/15 : EXPOSE 80
 ---> Using cache
 ---> 0572e560441e
Step 15/15 : CMD /bin/sh -c 'nginx -g "daemon off;"'
 ---> Running in 87bf69fddefa
Removing intermediate container 87bf69fddefa
 ---> 974db7c9c776
Successfully built 974db7c9c776
Successfully tagged mynginx:v2

由于在构建的过程中docker 会采用缓存机制,上面构建过程中包含很多using cache,所以这次构件非常快,如果需要重新构建,不想使用cache 需要添加 --no-cache

第三步: 启动并测试

[root@wallace mydocker]# docker run -d -p 81:80 mynginx:v2
79f40500a1e623ee8866cbdd63265fde58c1373b0e5fef914fb98cb9bc20ee83

第四步: 查看效果

版本三: 添加ENTRYPOINT

第一步: 编写Dockerfile

FROM centos:centos7

MAINTAINER wallace@163.com

RUN yum install make wget bzip2 -y

RUN mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

RUN wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo

RUN yum install automake gcc gcc-c++ autoconf zlib-devel openssl openssl-devel pcre* pcre-devel zlib -y

COPY nginx-1.8.0.tar.gz /opt/nginx/

COPY pcre-8.37.tar.bz2 /opt/pcre/

RUN tar xf /opt/pcre/pcre-8.37.tar.bz2 -C /usr/local/src/

RUN tar -xvzf /opt/nginx/nginx-1.8.0.tar.gz -C /usr/local/src/ 
    && useradd -M -s /sbin/nologin nginx

WORKDIR /usr/local/src/nginx-1.8.0

RUN ./configure 
--prefix=/usr/local/nginx
--with-http_dav_module
--with-http_stub_status_module
--with-http_addition_module
--with-http_sub_module
--with-http_flv_module
--with-http_mp4_module
--with-pcre=/usr/local/src/pcre-8.37 && make –j 3 ; make install ; cd ENV PATH=/usr/local/nginx/sbin:$PATH EXPOSE 80 # 使用ENTRYPOINT ENTRYPOINT ["nginx"] CMD ["-g", "daemon off;"]

第二步:构建镜像

[root@wallace mydocker]# docker build -t mynginx:v3 .

第三步:创建容器并测试

[root@wallace mydocker]# docker run -d -p 82:80 mynginx:v3

第四步:测试

第五步: 测试启动后自动关闭的模式 daemon off

FROM centos:centos7

MAINTAINER wallace@163.com

RUN yum install make wget bzip2 -y

RUN mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

RUN wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo

RUN yum install automake gcc gcc-c++ autoconf zlib-devel openssl openssl-devel pcre* pcre-devel zlib -y

COPY nginx-1.8.0.tar.gz /opt/nginx/

COPY pcre-8.37.tar.bz2 /opt/pcre/

RUN tar xf /opt/pcre/pcre-8.37.tar.bz2 -C /usr/local/src/

RUN tar -xvzf /opt/nginx/nginx-1.8.0.tar.gz -C /usr/local/src/ 
    && useradd -M -s /sbin/nologin nginx

WORKDIR /usr/local/src/nginx-1.8.0

RUN ./configure 
--prefix=/usr/local/nginx 
--with-http_dav_module 
--with-http_stub_status_module 
--with-http_addition_module 
--with-http_sub_module 
--with-http_flv_module 
--with-http_mp4_module 
--with-pcre=/usr/local/src/pcre-8.37 && make –j 3 ; make install ; cd

ENV PATH=/usr/local/nginx/sbin:$PATH

EXPOSE 80
# 使用ENTRYPOINT
ENTRYPOINT ["nginx"]

CMD ["-g", "daemon on;"]

测试:

[root@wallace mydocker]# docker run -d -p 84:80 mynginx:v3
e4b88651637f2f0edf1f90150b6ad66679d182ee2400237634c5f79ce1e8308f
[root@wallace mydocker]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                      PORTS                NAMES
e4b88651637f        mynginx:v3          "nginx -g 'daemon on…"   16 seconds ago      Exited (0) 15 seconds ago                        modest_wilson

启动后发现自动退出了容器,就是应为我们使用的是daemon on, 如果要正常启动可以加参数:

[root@wallace mydocker]# docker run -d -p 85:80 mynginx:v3 -g "daemon off;"
455b8dd411bc4fbf4228335e979e983c5ad2c64571a83fe2538b7c310c162182
[root@wallace mydocker]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED              STATUS                          PORTS                NAMES
455b8dd411bc        mynginx:v3          "nginx -g 'daemon of…"   3 seconds ago        Up 2 seconds                    0.0.0.0:85->80/tcp   cranky_chebyshev

然后就可以正常访问了

版本四: 添加VOLUMN

第一步:编写Dockerfile添加 VOLUMN指令

FROM centos:centos7

MAINTAINER wallace@163.com

RUN yum install make wget bzip2 -y

RUN mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

RUN wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo

RUN yum install automake gcc gcc-c++ autoconf zlib-devel openssl openssl-devel pcre* pcre-devel zlib -y

COPY nginx-1.8.0.tar.gz /opt/nginx/

COPY pcre-8.37.tar.bz2 /opt/pcre/

RUN tar xf /opt/pcre/pcre-8.37.tar.bz2 -C /usr/local/src/

RUN tar -xvzf /opt/nginx/nginx-1.8.0.tar.gz -C /usr/local/src/ 
    && useradd -M -s /sbin/nologin nginx
VOLUME ["/usr/local/nginx/html"]

WORKDIR /usr/local/src/nginx-1.8.0

RUN ./configure 
--prefix=/usr/local/nginx 
--with-http_dav_module 
--with-http_stub_status_module 
--with-http_addition_module 
--with-http_sub_module 
--with-http_flv_module 
--with-http_mp4_module 
--with-pcre=/usr/local/src/pcre-8.37 && make –j 3 ; make install ; cd

ENV PATH=/usr/local/nginx/sbin:$PATH

EXPOSE 80
# 使用ENTRYPOINT
ENTRYPOINT ["nginx"]

CMD ["-g", "daemon off;"]

第二步: 创建镜像

[root@wallace mydocker]# docker build -t mynginx:v5 .

第三步: 启动一个镜像

[root@wallace mydocker]# docker run -d -p 85:80 --name mynginx1 mynginx:v5 
# 然后查看镜像信息, 如下所示
[root@wallace mydocker]# docker inspect mynginx1
 "Mounts": [
            {
                "Type": "volume",
                "Name": "c2b140d1df296d5ded06a330e424a81ff5bff02ecb864da938bbfbeb00209e49",
                "Source": "/var/lib/docker/volumes/c2b140d1df296d5ded06a330e424a81ff5bff02ecb864da938bbfbeb00209e49/_data",
                "Destination": "/usr/local/nginx/html",
                "Driver": "local",
                "Mode": "",
                "RW": true,
                "Propagation": ""
            }
        ],

第四步进入到宿主机的挂载目录并且查看目录内的文件:

[root@wallace ~]# cd /var/lib/docker/volumes/c2b140d1df296d5ded06a330e424a81ff5bff02ecb864da938bbfbeb00209e49/_data/
[root@wallace _data]# ls
[root@wallace _data]# echo aaa > index.html
[root@wallace _data]# ls
index.html

第五步: 进入到docker查看

[root@wallace _data]# docker exec -it mynginx1 /bin/bash
[root@0adc63e5721b nginx-1.8.0]# cd /usr/local/nginx/html/
[root@0adc63e5721b html]# ls
[root@0adc63e5721b html]# ls
index.html

第六步: 验证

 通过访问发现,在宿主机上面进行了更改,容器内部也发生了变化,这样就动态的实现网站数据动态更改。

版本五: ONBUILD的使用

Dockerfile1中base image 为A镜像,并在Dockefile1中定义ONBUILD指令,构建成新的镜像B镜像

Dockerfile2中base image 为B镜像,构建成新镜像C

当使用镜像B启动容器1不会执行OBNUILD中定义的内容,而使用C镜像启动的容器2则会执行ONBUILD定义的内容

第一步: 编写Dockerfile添加ONBUILD指令

FROM centos:centos7

MAINTAINER wallace@163.com

RUN yum install make wget bzip2 -y

RUN mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

RUN wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo

RUN yum install automake gcc gcc-c++ autoconf zlib-devel openssl openssl-devel pcre* pcre-devel zlib -y

COPY nginx-1.8.0.tar.gz /opt/nginx/
COPY pcre-8.37.tar.bz2 /opt/pcre/ RUN tar xf /opt/pcre/pcre-8.37.tar.bz2 -C /usr/local/src/ RUN tar -xvzf /opt/nginx/nginx-1.8.0.tar.gz -C /usr/local/src/ && useradd -M -s /sbin/nologin nginx WORKDIR /usr/local/src/nginx-1.8.0 # 添加该指令 ONBUILD VOLUME ["/data"] RUN ./configure --prefix=/usr/local/nginx
--with-http_dav_module
--with-http_stub_status_module
--with-http_addition_module
--with-http_sub_module
--with-http_flv_module
--with-http_mp4_module
--with-pcre=/usr/local/src/pcre-8.37 && make –j 3 ; make install ; cd ENV PATH=/usr/local/nginx/sbin:$PATH EXPOSE 80 ENTRYPOINT ["nginx"] CMD ["-g", "daemon off;"]

第二步: 创建容器并启动测试

[root@server myNginx]# docker run -d -p 86:80 --name centos1 mycentos:v1
1f3c1672cce45e6f0f4e8d927de017fbe0a16f30858427d5cb3c2ec7f7b55d98
# 查看是否有/data目录
[root@server myNginx]# docker exec -it centos1 /bin/bash
[root@1f3c1672cce4 nginx-1.8.0]# ll /data
ls: cannot access /data: No such file or directory

第三步: 修改基础镜像,创建并验证

[root@wallace mydocker]# cat Dockerfile 
# 指定基础镜像
FROM mycentos:v1

# MAINTAINER
MAINTAINER wallace@qq.com
[root@wallace mydocker]# docker build -t mycentos:v3 . Sending build context to Docker daemon 2.394MB Step 1/2 : FROM mycentos:v1 # Executing 1 build trigger ---> Using cache ---> 4a8295471514 Step 2/2 : MAINTAINER wallace@163.com ---> Using cache ---> 92bfba2c223d Successfully built 92bfba2c223d Successfully tagged mycentos:v3
[root@wallace mydocker]# docker run -d -p 88:80 --name mycentos2 mycentos:v3
3ac3b3b563f45028aeaf56a99aaa43354625555e1d117da134bebcb9e92469b5
[root@wallace mydocker]# docker exec -it mycentos2 /bin/bash
[root@3ac3b3b563f4 nginx-1.8.0]# ls /d
data/ dev/

由此可见镜像v6包含了v5所有的内容,并且增加了ONBUILD的内容

[root@server ~]
原文地址:https://www.cnblogs.com/tashanzhishi/p/13398115.html