今天小編給大家分享一下怎么使用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鏡像”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。