高防服务器

怎么使用dockerfile构建nginx镜像


怎么使用dockerfile构建nginx镜像

发布时间:2022-03-24 17:53:37 来源:高防服务器网 阅读:56 作者:iii 栏目:web开发

今天小编给大家分享一下怎么使用dockerfile构建nginx镜像的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

dockerfile介绍

docker通过读取dockerfile里面的内容可以自动build image,dockerfile是一个包含了build过程中需要执行的所有命令的文本文件。也可以理解为dockfile是一种被docker程序解释的脚本,由一条一条的指令组成,每条指令对应linux系统下面的一条命令,由docker程序将这些dockerfile指令翻译成真正的linux命令。dockerfile有自己书写格式和支持的命令,docker程序解决这些命令间的依赖关系,类似于makefile。

docker程序将读取dockerfile,根据指令生成定制的image。相比image这种黑盒子,dockerfile这种显而易见的脚本更容易被使用者接受,它明确的表明image是怎么产生的。有了dockerfile,当我们需要定制自己额外的需求时,只需在dockerfile上添加或者修改指令,重新生成image即可,省去了敲命令的麻烦。

docker构建镜像的方法: commit、dockerfile

  1、使用commit来构建镜像:

    commit是基于原有镜像基础上构建的镜像,使用此方法构建镜像的目的:保存镜像里的一些配置信息和修改的信息。相当于一个镜像的快照。

  2、使用dockerfile来构建镜像:

    dockerfile是快速构建所需(自定义)镜像。

dockerfile的指令:

  from:指定基础镜像(from是必备的指令,并且必须为第一条指令)。

  run: 用来执行命令行命令。其基本格式:

      shell格式: run <命令> ,输入在bash环境中的命令即可,一个dockerfile允许使用run不得超过127层,所以,使用一次run, 使用 ‘ ' 换行,使用‘ && '执行下一条命令。一般使用此种格式;

      exec格式: run <"可执行文件", "参数1", "参数2">,此种方式像是函数调用中的格式;

  copy: 复制文件。 其基本格式:

      格式1:copy <源路径>…<目标路径>

      格式2:copy [“<源路径1>”,….."<目标路径>"]

  add: 更高级的复制文件,在copy的基础上增加了一些功能,如果复制的是压缩包的话,会直接解压,而不需要在使用run解压;

  cmd:容器启动命令。其基本格式:

      shell格式: cmd <命令>

      exec格式: cmd ["可执行文件", "参数1", "参数2"…]

      参数列表格式: cmd [“参数1”, “参数2”…],在指定了entrypoint指令后,用cmd指定具体的参数

  entrypoint: 入口点。其基本格式分为exec和shell,

      entrypoint的目的和cmd一样,都是在指定容器启动程序及参数。entrypoint在运行中可以替代,不过比cmd繁琐,需要通过docker run 的参数–entrypoint 来指定。当指定了entrypoint后,cmd的含义就发生了改变,不在是直接运行其命令,而是将cmd的内容作为参数传递给entrypoint指令。其执行时就变成了: <entrypoint> "<cmd>"

  env: 设置环境变量。(都可以使用这里使用的变量)其基本格式:

      格式1:env <key> <value>

      格式2:env <key1>=<value1> <key2>=<value>…

  arg: 构建参数。构建参数和env的效果一样,都是设置环境变量,所不同的是arg所构建的环境变量在将来容器运行时是不存在的。其基本格式:

      格式1: arg <参数名> [=<默认值>]

      格式2: 该默认值可以在构建命令 docker build 中用 –build-arg <参数名>=<值> 来覆盖

  volume: 定义匿名卷。 其基本格式:

      格式1: volume ["<路径1>", "<路径2>"…]

      格式2: volume <路径>

  expose: 暴露端口。expose指令是声明运行时容器所提供的端口,在启动容器时不会在因为这个声明而开启端口。 其基本格式:

      格式1: expose <端口1> [<端口2>…]

  workdir: 指定工作目录。其基本格式:

      格式1: workdir <工作目录路径>

  user: 指定当前用户。user是帮助你切换到指定用户。 其基本格式:

      格式1: user <用户名>

  healtcheck: 健康检查,判断容器的状态是否正常。 其基本格式:

      格式1: healtcheck [选项] cmd <命令> :设置检查容器健康状况的命令

      格式2: healtcheck none: 如果基础镜像有健康检查指令,使用此格式可以屏蔽掉其健康检查指令

构建nginx镜像:

创建一个目录,在该目录里编写dockerfile:

[root@docker ~]# mkdir mynginx  [root@docker ~]# cd mynginx/  [root@docker mynginx]# pwd  /root/mynginx  [root@docker mynginx]#

下载nginx源码包到创建的目录下(mynginx目录下):

[root@docker ~]# wget -p /root/mynginx/ http://nginx.org/download/nginx-1.15.2.tar.gz

编写dockerfile:

[root@docker mynginx]# vi dockerfile

其内容如下:

from centos  run ping -c 1 www.baidu.com  run yum -y install gcc make pcre-devel zlib-devel tar zlib  add nginx-1.15.2.tar.gz /usr/src/  run cd /usr/src/nginx-1.15.2     && mkdir /usr/local/nginx     && ./configure --prefix=/usr/local/nginx && make && make install     && ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/     && nginx  run rm -rf /usr/src/nginx-1.15.2  expose 80

运行docker命令构建镜像:

[root@docker mynginx]# docker build -t nginx:v3 .  sending build context to docker daemon 1.029mb  step 1/7 : from centos   ---> 5182e96772bf  step 2/7 : run ping -c 1 www.baidu.com   ---> using cache   ---> 2f70f8abaf2a  step 3/7 : run yum -y install gcc make pcre-devel zlib-devel tar zlib   ---> using cache   ---> dbdda4b7ae6f  step 4/7 : add nginx-1.15.2.tar.gz /usr/src/   ---> using cache   ---> 18ace6285668  step 5/7 : run cd /usr/src/nginx-1.15.2   && mkdir /usr/local/nginx   && ./configure --prefix=/usr/local/nginx && make && make install   && ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/   && nginx   ---> using cache   ---> 99629488ede9  step 6/7 : run rm -rf /usr/src/nginx-1.15.2   ---> using cache   ---> 869fbad71879  step 7/7 : expose 80   ---> using cache   ---> 384bed72ea6f  successfully built 384bed72ea6f  successfully tagged nginx:v3

输出两个successfully即为构建成功!

启动自定义镜像:

使用 docker images 查看构建的镜像:

启动自定义的镜像:

[root@docker ~]# docker run -dit -p 80:80 --name nginx nginx:v3  ecaafe1190447878b98dfb0198e92439db60ff7dab57a1674e0e9e7282a9c858  [root@docker ~]# docker ps -a  container id    image        command       created       status       ports        names  ecaafe119044    nginx:v3      "/bin/bash"     3 seconds ago    up 2 seconds    0.0.0.0:80->80/tcp  nginx

注:这时,你无论怎么启动这个容器,它还是一直处于exited状态。

经过各种解决,最终,终于知道问题出在了哪。 原来容器启动时,它是在后台对应着一个线程启动的,它在启动时是已经启动了,但它执行完命令后,就退出了,并没有在后台运行着,所以使用 -dit 参数让它在后台运行即可。

[root@docker ~]# docker run -dit -p 80:80 --name nginx nginx:v3  ecaafe1190447878b98dfb0198e92439db60ff7dab57a1674e0e9e7282a9c858  [root@docker ~]# docker ps -a  container id    image        command       created       status       ports        names  ecaafe119044    nginx:v3      "/bin/bash"     3 seconds ago    up 2 seconds    0.0.0.0:80->80/tcp  nginx

然而…….

此时又出现了问题,它虽然起来了,但nginx的web网页界面访问不了,显示拒绝连接!!!!

[root@docker ~]# curl 192.168.100.22  curl: (7) failed connect to 192.168.100.22:80; 拒绝连接  [root@docker ~]# elinks --dump 192.168.100.22  elinks: 拒绝连接

然后,又经过问百度,fq看谷歌,终于找到了问题的所在。原来只要使用 exec 进入到容器里启动nginx就可以了。

[root@docker ~]# docker exec -it nginx bash  [root@ecaafe119044 /]# nginx  [root@ecaafe119044 /]# exit  exit
[root@docker ~]# curl 192.168.100.22  <!doctype html>  <html>  <head>  <title>welcome to nginx!</title>  <style>    body {      width: 35em;      margin: 0 auto;      font-family: tahoma, verdana, arial, sans-serif;    }  </style>  </head>  <body>  <h1>welcome to nginx!</h1>  <p>if you see this page, the nginx web server is successfully installed and  working. further configuration is required.</p>    <p>for online documentation and support please refer to  <a href="http://nginx.org/" rel="external nofollow" >nginx.org</a>.<br/>  commercial support is available at  <a href="http://nginx.com/" rel="external nofollow" >nginx.com</a>.</p>    <p><em>thank you for using nginx.</em></p>  </body>  </html>

以上就是“怎么使用dockerfile构建nginx镜像”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注高防服务器网行业资讯频道。

[微信提示:高防服务器能助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。

[图文来源于网络,不代表本站立场,如有侵权,请联系高防服务器网删除]
[