使用dockerfile构建nginx镜像

Version:1.0 StartHTML:000000211 EndHTML:000017458 StartFragment:000001829 EndFragment:000017372 StartSelection:000001829 EndSelection:000017368 SourceURL:https://www.cnblogs.com/zhhuihui/p/docker_z.html <title>使用dockerfile构建nginx镜像 - zhhuicom - 博客园</title><link href="/bundles/blog-common.css?v=giTNza-Of-PEt5UsELhFQAR7G6-bfaSa4oolcq7i9-o1" rel="stylesheet" type="text/css"><link id="MainCss" href="/skins/coffee/bundle-coffee.css?v=NnZbvdgFaQNhu3t8P4Wsaz98sDQkgRt7Qxq2rzF0ZRU1" rel="stylesheet" type="text/css"><link id="mobile-style" href="/skins/coffee/bundle-coffee-mobile.css?v=EhLLUe5NHsx18JODVZscd5ef3A8WbJHKTlTvuKQjsl01" rel="stylesheet" type="text/css" media="only screen and (max-width: 767px)"><link title="RSS" href="https://www.cnblogs.com/zhhuihui/rss" rel="alternate" type="application/rss+xml"><link title="RSD" href="https://www.cnblogs.com/zhhuihui/rsd.xml" rel="EditURI" type="application/rsd+xml"><link href="https://www.cnblogs.com/zhhuihui/wlwmanifest.xml" rel="wlwmanifest" type="application/wlwmanifest+xml"> <script type="text/javascript">var currentBlogApp = 'zhhuihui', cb_enable_mathjax=false;var isLogined=true;</script>

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:

?

|

1

2

3

4

5

|

[root@docker ~]``# mkdir mynginx

[root@docker ~]``# cd mynginx/

[root@docker mynginx]``# pwd

/root/mynginx

[root@docker mynginx]``#

|

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

?

|

1

|

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

|

编写Dockerfile:

<pre>[root@docker mynginx]# vi Dockerfile</pre>

其内容如下:

+ View Code?

|

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命令构建镜像:

[[图片上传失败...(image-8046ed-1536332011514)]](javascript:void(0); "复制代码")

<pre>[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</pre>

[[图片上传失败...(image-dd874e-1536332011514)]](javascript:void(0); "复制代码")

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


启动自定义镜像:

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

image

启动自定义的镜像:

[[图片上传失败...(image-2fdd33-1536332011514)]](javascript:void(0); "复制代码")

<pre>[root@docker ~]# docker run -d -p 80:80 --name nginx nginx:v3
4ac935e955b1c3ac49eed68f3372f3e96a8934fd8ccf4614afa3d7c29eb96c08
[root@docker ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4ac935e955b1 nginx:v3 "/bin/bash" 3 seconds ago Exited (0) 2 seconds ago nginx</pre>

[[图片上传失败...(image-944da0-1536332011514)]](javascript:void(0); "复制代码")

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

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

<pre>[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</pre>

然而.......

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

<pre>[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: 拒绝连接</pre>

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

<pre>[root@docker ~]# docker exec -it nginx bash
[root@ecaafe119044 /]# nginx
[root@ecaafe119044 /]# exit
exit</pre>

[[图片上传失败...(image-24d6cf-1536332011514)]](javascript:void(0); "复制代码")

<pre>[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/">nginx.org</a>.
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>
</html></pre>

[[图片上传失败...(image-4471cb-1536332011514)]](javascript:void(0); "复制代码")

这样! nginx镜像就购将成功了!!!!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 197,368评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,941评论 2 374
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 144,369评论 0 326
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,848评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,719评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,505评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,904评论 3 388
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,528评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,819评论 1 293
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,848评论 2 314
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,652评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,468评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,912评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,095评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,389评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,906评论 2 343
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,120评论 2 339

推荐阅读更多精彩内容