首頁 > 運維 > Nginx > 怎麼使用dockerfile建置nginx映像

怎麼使用dockerfile建置nginx映像

WBOY
發布: 2023-05-14 20:13:10
轉載
4203 人瀏覽過

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 ,此種方式像是函數呼叫中的格式;

  copy: 複製檔案。其基本格式:

      格式1:copy ...

      」格式2:copy [##      發格式2:copy [“"]

  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指令。其執行時就變成了: ""

#  env: 設定環境變數。 (都可以使用這裡使用的變數)其基本格式:

      格式1:env

     行格式:26; =...

  arg: 建置參數。建構參數和env的效果一樣,都是設定環境變量,不同的是arg所建構的環境變數在將來容器執行時是不存在的。其基本格式:

      格式1: arg [=]

#      格式/設定 此預設值-build-arg = 來覆寫

  volume: 定義匿名磁碟區。其基本格式:

      格式1:volume ["", ""...]

##      路徑2>"...]

##      

##  expose: 暴露埠。 expose指令是聲明運行時容器所提供的端口,在啟動容器時不會在因為這個聲明而開啟端口。其基本格式:

      格式1: expose [...]

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

      格式1: workdir

  user: 指定目前使用者。 user是幫助你切換到指定使用者。其基本格式:

      格式1: user

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

      格式1: healtcheck [選項] cmd :設定檢查容器健康狀況的指令

##     與健康指令 2:

       〔健康指令格式。 ,使用此格式可以屏蔽掉其健康檢查指令

建置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 查看建置的映像:

怎麼使用dockerfile建置nginx映像

啟動自訂的映像:

[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映像的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板