使用dockerfile構(gòu)建nginx鏡像的方法示例
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有自己書寫格式和支持的命令,Docker程序解決這些命令間的依賴關(guān)系,類似于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ì)直接解壓,而不需要在使用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)前用戶。USER是幫助你切換到指定用戶。 其基本格式:
格式1: USER <用戶名>
HEALTCHECK: 健康檢查,判斷容器的狀態(tài)是否正常。 其基本格式:
格式1: HEALTCHECK [選項(xiàng)] CMD <命令> :設(shè)置檢查容器健康狀況的命令
格式2: HEALTCHECK NONE: 如果基礎(chǔ)鏡像有健康檢查指令,使用此格式可以屏蔽掉其健康檢查指令
構(gòu)建nginx鏡像:
創(chuàng)建一個(gè)目錄,在該目錄里編寫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
編寫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)建的鏡像:
啟動(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è)線程啟動(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è)界面訪問(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)百度,F(xiàn)Q看谷歌,終于找到了問(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 rel="external nofollow" >nginx.org</a>.<br/> Commercial support is available at <a rel="external nofollow" >nginx.com</a>.</p> <p><em>Thank you for using nginx.</em></p> </body> </html>
這樣! nginx鏡像就購(gòu)將成功了!?。。?/p>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
docker Compose部署springboot+vue前端端分離
本文主要介紹了docker Compose部署springboot+vue前端端分離,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08Docker宿主機(jī)與容器之間的文件拷貝實(shí)例詳解
現(xiàn)在公司用docker,有時(shí)候需要從容器中拷貝文件出來(lái),下面這篇文章主要給大家介紹了關(guān)于Docker宿主機(jī)與容器之間的文件拷貝的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06windows壞境下docker使用phpmyamin的權(quán)限問(wèn)題解決
這篇文章主要為大家介紹了windows壞境下docker使用phpmyamin發(fā)生的權(quán)限問(wèn)題解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12一文詳解如何配置docker通過(guò)代理服務(wù)器拉取鏡像
這篇文章主要給大家介紹了關(guān)于如何配置docker通過(guò)代理服務(wù)器拉取鏡像的相關(guān)資料,如果在拉取Docker鏡像時(shí)遇到速度較慢的問(wèn)題,可以嘗試以下幾種方法解決,需要的朋友可以參考下2024-07-07IntelliJ IDEA(2018版)安裝docker插件的詳細(xì)過(guò)程
這篇文章主要介紹了IntelliJ IDEA安裝docker插件的詳細(xì)過(guò)程,開(kāi)發(fā)工具使用的是IDEA2018.16版,本文通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09