zoukankan      html  css  js  c++  java
  • 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 ~]
  • 相关阅读:
    csrf漏洞
    WebServer远程部署
    URL跳转与钓鱼
    代码注入
    暴跌之后-如何低位灵活补仓
    操盘策略:在交易之前做好应变准备
    操盘策略:股价异动未必主力所为
    赖在长沙的50个理由
    倒在黎明前:融资客股市震荡中被强*损失850万
    操盘策略:巧用盘中T+0交易
  • 原文地址:https://www.cnblogs.com/tashanzhishi/p/13398115.html
Copyright © 2011-2022 走看看