溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

怎么使用dockerfile構(gòu)建nginx鏡像

發(fā)布時(shí)間:2022-03-24 17:53:37 來(lái)源:億速云 閱讀:852 作者:iii 欄目:web開(kāi)發(fā)

今天小編給大家分享一下怎么使用dockerfile構(gòu)建nginx鏡像的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來(lái)了解一下吧。

dockerfile介紹

docker通過(guò)讀取dockerfile里面的內(nèi)容可以自動(dòng)build image,dockerfile是一個(gè)包含了build過(guò)程中需要執(zhí)行的所有命令的文本文件。也可以理解為dockfile是一種被docker程序解釋的腳本,由一條一條的指令組成,每條指令對(duì)應(yīng)linux系統(tǒng)下面的一條命令,由docker程序?qū)⑦@些dockerfile指令翻譯成真正的linux命令。dockerfile有自己書(shū)寫(xiě)格式和支持的命令,docker程序解決這些命令間的依賴(lài)關(guān)系,類(lèi)似于makefile。

docker程序?qū)⒆x取dockerfile,根據(jù)指令生成定制的image。相比image這種黑盒子,dockerfile這種顯而易見(jiàn)的腳本更容易被使用者接受,它明確的表明image是怎么產(chǎn)生的。有了dockerfile,當(dāng)我們需要定制自己額外的需求時(shí),只需在dockerfile上添加或者修改指令,重新生成image即可,省去了敲命令的麻煩。

docker構(gòu)建鏡像的方法: commit、dockerfile

  1、使用commit來(lái)構(gòu)建鏡像:

    commit是基于原有鏡像基礎(chǔ)上構(gòu)建的鏡像,使用此方法構(gòu)建鏡像的目的:保存鏡像里的一些配置信息和修改的信息。相當(dāng)于一個(gè)鏡像的快照。

  2、使用dockerfile來(lái)構(gòu)建鏡像:

    dockerfile是快速構(gòu)建所需(自定義)鏡像。

dockerfile的指令:

  from:指定基礎(chǔ)鏡像(from是必備的指令,并且必須為第一條指令)。

  run: 用來(lái)執(zhí)行命令行命令。其基本格式:

      shell格式: run <命令> ,輸入在bash環(huán)境中的命令即可,一個(gè)dockerfile允許使用run不得超過(guò)127層,所以,使用一次run, 使用 ‘ \' 換行,使用‘ && '執(zhí)行下一條命令。一般使用此種格式;

      exec格式: run <"可執(zhí)行文件", "參數(shù)1", "參數(shù)2">,此種方式像是函數(shù)調(diào)用中的格式;

  copy: 復(fù)制文件。 其基本格式:

      格式1:copy <源路徑>...<目標(biāo)路徑>

      格式2:copy [“<源路徑1>”,....."<目標(biāo)路徑>"]

  add: 更高級(jí)的復(fù)制文件,在copy的基礎(chǔ)上增加了一些功能,如果復(fù)制的是壓縮包的話(huà),會(huì)直接解壓,而不需要在使用run解壓;

  cmd:容器啟動(dòng)命令。其基本格式:

      shell格式: cmd <命令>

      exec格式: cmd ["可執(zhí)行文件", "參數(shù)1", "參數(shù)2"...]

      參數(shù)列表格式: cmd [“參數(shù)1”, “參數(shù)2”...],在指定了entrypoint指令后,用cmd指定具體的參數(shù)

  entrypoint: 入口點(diǎn)。其基本格式分為exec和shell,

      entrypoint的目的和cmd一樣,都是在指定容器啟動(dòng)程序及參數(shù)。entrypoint在運(yùn)行中可以替代,不過(guò)比cmd繁瑣,需要通過(guò)docker run 的參數(shù)--entrypoint 來(lái)指定。當(dāng)指定了entrypoint后,cmd的含義就發(fā)生了改變,不在是直接運(yùn)行其命令,而是將cmd的內(nèi)容作為參數(shù)傳遞給entrypoint指令。其執(zhí)行時(shí)就變成了: <entrypoint> "<cmd>"

  env: 設(shè)置環(huán)境變量。(都可以使用這里使用的變量)其基本格式:

      格式1:env <key> <value>

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

  arg: 構(gòu)建參數(shù)。構(gòu)建參數(shù)和env的效果一樣,都是設(shè)置環(huán)境變量,所不同的是arg所構(gòu)建的環(huán)境變量在將來(lái)容器運(yùn)行時(shí)是不存在的。其基本格式:

      格式1: arg <參數(shù)名> [=<默認(rèn)值>]

      格式2: 該默認(rèn)值可以在構(gòu)建命令 docker build 中用 --build-arg <參數(shù)名>=<值> 來(lái)覆蓋

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

      格式1: volume ["<路徑1>", "<路徑2>"...]

      格式2: volume <路徑>

  expose: 暴露端口。expose指令是聲明運(yùn)行時(shí)容器所提供的端口,在啟動(dòng)容器時(shí)不會(huì)在因?yàn)檫@個(gè)聲明而開(kāi)啟端口。 其基本格式:

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

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

      格式1: workdir <工作目錄路徑>

  user: 指定當(dāng)前用戶(hù)。user是幫助你切換到指定用戶(hù)。 其基本格式:

      格式1: user <用戶(hù)名>

  healtcheck: 健康檢查,判斷容器的狀態(tài)是否正常。 其基本格式:

      格式1: healtcheck [選項(xiàng)] cmd <命令> :設(shè)置檢查容器健康狀況的命令

      格式2: healtcheck none: 如果基礎(chǔ)鏡像有健康檢查指令,使用此格式可以屏蔽掉其健康檢查指令

構(gòu)建nginx鏡像:

創(chuàng)建一個(gè)目錄,在該目錄里編寫(xiě)dockerfile:

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

下載nginx源碼包到創(chuàng)建的目錄下(mynginx目錄下):

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

編寫(xiě)dockerfile:

[root@docker mynginx]# vi dockerfile

其內(nèi)容如下:

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

運(yùn)行docker命令構(gòu)建鏡像:

[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

輸出兩個(gè)successfully即為構(gòu)建成功!

啟動(dòng)自定義鏡像:

使用 docker images 查看構(gòu)建的鏡像:

怎么使用dockerfile構(gòu)建nginx鏡像

啟動(dòng)自定義的鏡像:

[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

注:這時(shí),你無(wú)論怎么啟動(dòng)這個(gè)容器,它還是一直處于exited狀態(tài)。

經(jīng)過(guò)各種解決,最終,終于知道問(wèn)題出在了哪。 原來(lái)容器啟動(dòng)時(shí),它是在后臺(tái)對(duì)應(yīng)著一個(gè)線(xiàn)程啟動(dòng)的,它在啟動(dòng)時(shí)是已經(jīng)啟動(dòng)了,但它執(zhí)行完命令后,就退出了,并沒(méi)有在后臺(tái)運(yùn)行著,所以使用 -dit 參數(shù)讓它在后臺(tái)運(yùn)行即可。

[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

然而.......

此時(shí)又出現(xiàn)了問(wèn)題,它雖然起來(lái)了,但nginx的web網(wǎng)頁(yè)界面訪(fǎng)問(wèn)不了,顯示拒絕連接?。。?!

[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: 拒絕連接

然后,又經(jīng)過(guò)問(wèn)百度,fq看谷歌,終于找到了問(wèn)題的所在。原來(lái)只要使用 exec 進(jìn)入到容器里啟動(dòng)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構(gòu)建nginx鏡像”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI