Dockerfile文件詳解
什么是dockerfile?
Dockerfile是一個(gè)包含用于組合映像的命令的文本文檔。可以使用在命令行中調(diào)用任何命令。 Docker通過(guò)讀取Dockerfile中的指令自動(dòng)生成映像。
docker build命令用于從Dockerfile構(gòu)建映像??梢栽?code>docker build命令中使用-f標(biāo)志指向文件系統(tǒng)中任何位置的Dockerfile。
例:
docker build -f /path/to/a/Dockerfile
Dockerfile的基本結(jié)構(gòu)
Dockerfile 一般分為四部分:基礎(chǔ)鏡像信息、維護(hù)者信息、鏡像操作指令和容器啟動(dòng)時(shí)執(zhí)行指令,’#’為 Dockerfile 中的注釋。
Dockerfile文件說(shuō)明
Docker以從上到下的順序運(yùn)行Dockerfile的指令。為了指定基本映像,第一條指令必須是FROM。一個(gè)聲明以#字符開頭則被視為注釋??梢栽贒ocker文件中使用RUN,CMD,FROM,EXPOSE,ENV等指令。
在這里列出了一些常用的指令。
FROM
指定基礎(chǔ)鏡像,必須為第一個(gè)命令
#格式: FROM <image> FROM <image>:<tag> FROM <image>@<digest> #示例: FROM mysql:5.6
注:tag或digest是可選的,如果不使用這兩個(gè)值時(shí),會(huì)使用latest版本的基礎(chǔ)鏡像
MAINTAINER
維護(hù)者信息
#格式:
MAINTAINER <name>
#示例:
MAINTAINER Jasper Xu
MAINTAINER sorex@163.com
MAINTAINER Jasper Xu <sorex@163.com>RUN
構(gòu)建鏡像時(shí)執(zhí)行的命令
RUN用于在鏡像容器中執(zhí)行命令,其有以下兩種命令執(zhí)行方式:
shell執(zhí)行
#格式:
RUN <command>exec執(zhí)行
#格式:
RUN ["executable", "param1", "param2"]
#示例:
RUN ["executable", "param1", "param2"]
RUN apk update
RUN ["/etc/execfile", "arg1", "arg1"]注:RUN指令創(chuàng)建的中間鏡像會(huì)被緩存,并會(huì)在下次構(gòu)建中使用。如果不想使用這些緩存鏡像,可以在構(gòu)建時(shí)指定--no-cache參數(shù),如:docker build --no-cache
ADD
將本地文件添加到容器中,tar類型文件會(huì)自動(dòng)解壓(網(wǎng)絡(luò)壓縮資源不會(huì)被解壓),可以訪問(wèn)網(wǎng)絡(luò)資源,類似wget
#格式:
ADD <src>... <dest>
ADD ["<src>",... "<dest>"] 用于支持包含空格的路徑
#示例:
ADD hom* /mydir/ # 添加所有以"hom"開頭的文件
ADD hom?.txt /mydir/ # ? 替代一個(gè)單字符,例如:"home.txt"
ADD test relativeDir/ # 添加 "test" 到 `WORKDIR`/relativeDir/
ADD test /absoluteDir/ # 添加 "test" 到 /absoluteDir/COPY
功能類似ADD,但是是不會(huì)自動(dòng)解壓文件,也不能訪問(wèn)網(wǎng)絡(luò)資源
CMD
構(gòu)建容器后調(diào)用,也就是在容器啟動(dòng)時(shí)才進(jìn)行調(diào)用。
#格式:
CMD ["executable","param1","param2"] (執(zhí)行可執(zhí)行文件,優(yōu)先)
CMD ["param1","param2"] (設(shè)置了ENTRYPOINT,則直接調(diào)用ENTRYPOINT添加參數(shù))
CMD command param1 param2 (執(zhí)行shell內(nèi)部命令)
#示例:
CMD echo "This is a test." | wc -
CMD ["/usr/bin/wc","--help"]注:CMD不同于RUN,CMD用于指定在容器啟動(dòng)時(shí)所要執(zhí)行的命令,而RUN用于指定鏡像構(gòu)建時(shí)所要執(zhí)行的命令。[/code]
ENTRYPOINT
配置容器,使其可執(zhí)行化。配合CMD可省去"application",只使用參數(shù)。
#格式:
ENTRYPOINT ["executable", "param1", "param2"] (可執(zhí)行文件, 優(yōu)先)
ENTRYPOINT command param1 param2 (shell內(nèi)部命令)
#示例:
FROM ubuntu
ENTRYPOINT ["top", "-b"]
CMD ["-c"]注:ENTRYPOINT與CMD非常類似,不同的是通過(guò)docker run執(zhí)行的命令不會(huì)覆蓋ENTRYPOINT,而docker run命令中指定的任何參數(shù),都會(huì)被當(dāng)做參數(shù)再次傳遞給ENTRYPOINT。Dockerfile中只允許有一個(gè)ENTRYPOINT命令,多指定時(shí)會(huì)覆蓋前面的設(shè)置,而只執(zhí)行最后的ENTRYPOINT指令。
LABEL
用于為鏡像添加元數(shù)據(jù)
#格式:
LABEL <key>=<value> <key>=<value> <key>=<value> ...
#示例:
LABEL version="1.0" description="這是一個(gè)Web服務(wù)器" by="IT筆錄"注:使用LABEL指定元數(shù)據(jù)時(shí),一條LABEL指定可以指定一或多條元數(shù)據(jù),指定多條元數(shù)據(jù)時(shí)不同元數(shù)據(jù)之間通過(guò)空格分隔。推薦將所有的元數(shù)據(jù)通過(guò)一條LABEL指令指定,以免生成過(guò)多的中間鏡像。
ENV
設(shè)置環(huán)境變量
#格式:
ENV <key> <value> #<key>之后的所有內(nèi)容均會(huì)被視為其<value>的組成部分,因此,一次只能設(shè)置一個(gè)變量
ENV <key>=<value> ... #可以設(shè)置多個(gè)變量,每個(gè)變量為一個(gè)"<key>=<value>"的鍵值對(duì),如果<key>中包含空格,可以使用\來(lái)進(jìn)行轉(zhuǎn)義,也可以通過(guò)""來(lái)進(jìn)行標(biāo)示;另外,反斜線也可以用于續(xù)行
#示例:
ENV myName John Doe
ENV myDog Rex The Dog
ENV myCat=fluffyEXPOSE
指定于外界交互的端口
#格式:
EXPOSE <port> [<port>...]
#示例:
EXPOSE 80 443
EXPOSE 8080
EXPOSE 11211/tcp 11211/udp注:EXPOSE并不會(huì)讓容器的端口訪問(wèn)到主機(jī)。要使其可訪問(wèn),需要在docker run運(yùn)行容器時(shí)通過(guò)-p來(lái)發(fā)布這些端口,或通過(guò)-P參數(shù)來(lái)發(fā)布EXPOSE導(dǎo)出的所有端口
VOLUME
用于指定持久化目錄
#格式:
VOLUME ["/path/to/dir"]
#示例:
VOLUME ["/data"]
VOLUME ["/var/www", "/var/log/apache2", "/etc/apache2"注:一個(gè)卷可以存在于一個(gè)或多個(gè)容器的指定目錄,該目錄可以繞過(guò)聯(lián)合文件系統(tǒng),并具有以下功能:
- 1 卷可以容器間共享和重用
- 2 容器并不一定要和其它容器共享卷
- 3 修改卷后會(huì)立即生效
- 4 對(duì)卷的修改不會(huì)對(duì)鏡像產(chǎn)生影響
- 5 卷會(huì)一直存在,直到?jīng)]有任何容器在使用它
WORKDIR
工作目錄,類似于cd命令
#格式:
WORKDIR /path/to/workdir
#示例:
WORKDIR /a (這時(shí)工作目錄為/a)
WORKDIR b (這時(shí)工作目錄為/a/b)
WORKDIR c (這時(shí)工作目錄為/a/b/c)注:通過(guò)WORKDIR設(shè)置工作目錄后,Dockerfile中其后的命令RUN、CMD、ENTRYPOINT、ADD、COPY等命令都會(huì)在該目錄下執(zhí)行。在使用docker run運(yùn)行容器時(shí),可以通過(guò)-w參數(shù)覆蓋構(gòu)建時(shí)所設(shè)置的工作目錄。
USER
指定運(yùn)行容器時(shí)的用戶名或 UID,后續(xù)的 RUN 也會(huì)使用指定用戶。使用USER指定用戶時(shí),可以使用用戶名、UID或GID,或是兩者的組合。當(dāng)服務(wù)不需要管理員權(quán)限時(shí),可以通過(guò)該命令指定運(yùn)行用戶。并且可以在之前創(chuàng)建所需要的用戶
#格式: USER user USER user:group USER uid USER uid:gid USER user:gid USER uid:group #示例: USER www
注:使用USER指定用戶后,Dockerfile中其后的命令RUN、CMD、ENTRYPOINT都將使用該用戶。鏡像構(gòu)建完成后,通過(guò)docker run運(yùn)行容器時(shí),可以通過(guò)-u參數(shù)來(lái)覆蓋所指定的用戶。
ARG
用于指定傳遞給構(gòu)建運(yùn)行時(shí)的變量
#格式:
ARG <name>[=<default value>]
#示例:
ARG site
ARG build_user=wwwONBUILD
用于設(shè)置鏡像觸發(fā)器
#格式: ONBUILD [INSTRUCTION] #示例: ONBUILD ADD . /app/src ONBUILD RUN /usr/local/bin/python-build --dir /app/src
注:當(dāng)所構(gòu)建的鏡像被用做其它鏡像的基礎(chǔ)鏡像,該鏡像中的觸發(fā)器將會(huì)被鑰觸發(fā)
以下是一個(gè)小例子:
# This my first nginx Dockerfile # Version 1.0 # Base images 基礎(chǔ)鏡像 FROM centos #MAINTAINER 維護(hù)者信息 MAINTAINER tianfeiyu #ENV 設(shè)置環(huán)境變量 ENV PATH /usr/local/nginx/sbin:$PATH #ADD 文件放在當(dāng)前目錄下,拷過(guò)去會(huì)自動(dòng)解壓 ADD nginx-1.8.0.tar.gz /usr/local/ ADD epel-release-latest-7.noarch.rpm /usr/local/ #RUN 執(zhí)行以下命令 RUN rpm -ivh /usr/local/epel-release-latest-7.noarch.rpm RUN yum install -y wget lftp gcc gcc-c++ make openssl-devel pcre-devel pcre && yum clean all RUN useradd -s /sbin/nologin -M www #WORKDIR 相當(dāng)于cd WORKDIR /usr/local/nginx-1.8.0 RUN ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_ssl_module --with-pcre && make && make install RUN echo "daemon off;" >> /etc/nginx.conf #EXPOSE 映射端口 EXPOSE 80 #CMD 運(yùn)行以下命令 CMD ["nginx"]
最后用一張圖解釋常用指令的意義^-^

到此這篇關(guān)于Dockerfile文件的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Docker部署java項(xiàng)目的詳細(xì)步驟(利用Dockerfile方式)
- docker 編輯Dockerfile 添加php7.2 acpu的問(wèn)題
- Python?Web?App開發(fā)Dockerfiles編寫示例
- docker通過(guò)Dockerfile構(gòu)建mysql鏡像的方法
- 如何使用?Dockerfile?創(chuàng)建一個(gè)簡(jiǎn)單容器
- dockerfile指令構(gòu)建docker鏡像的示例代碼
- 使用Dockerfile實(shí)現(xiàn)數(shù)據(jù)卷的掛載問(wèn)題(推薦)
- 利用Dockerfile優(yōu)化Nestjs構(gòu)建鏡像大小詳情
相關(guān)文章
Centos8安裝docker報(bào)錯(cuò)(錯(cuò)誤提示:All?mirrors?were?tried)的問(wèn)題
最近總是遇到“All?mirrors?were?tried”的報(bào)錯(cuò)信息,沒(méi)辦法,就rm?-rf?/etc/yum.repos.d/*?全部!刪了,下面小編通過(guò)本文給大家介紹下Centos8安裝docker報(bào)錯(cuò)(錯(cuò)誤提示:All?mirrors?were?tried)的問(wèn)題及解決過(guò)程,感興趣的朋友一起看看吧2022-03-03
SQL?Server?簡(jiǎn)介與?Docker?Compose?部署SQL?Server?容器
SQL?Server?是一個(gè)功能強(qiáng)大的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),適用于各種規(guī)模的應(yīng)用程序和數(shù)據(jù)存儲(chǔ)需求,在本文中,我將簡(jiǎn)要介紹?SQL?Server?的基本概念,并詳細(xì)闡述如何使用?Docker?Compose?部署?SQL?Server?容器,感興趣的朋友跟隨小編一起看看吧2023-10-10
使用docker部署一個(gè)簡(jiǎn)單的c/c++程序的方法
這篇文章主要介紹了使用docker部署一個(gè)簡(jiǎn)單的c/c++程序的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
安裝Docker Desktop報(bào)錯(cuò)WSL 2 installation is incomplete的問(wèn)題(解決報(bào)錯(cuò))
這篇文章主要介紹了安裝Docker Desktop報(bào)錯(cuò)WSL 2 installation is incomplete的問(wèn)題,解決方法很簡(jiǎn)單只需我們自己手動(dòng)更新一下,我們根據(jù)提示去微軟官網(wǎng)下載最新版的wsl2安裝后即可正常打開,需要的朋友可以參考下2021-06-06
Docker部署Rabbitmq容器實(shí)現(xiàn)過(guò)程解析
這篇文章主要介紹了Docker部署Rabbitmq容器實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
Docker拉取鏡像過(guò)慢或卡死的解決方法(親測(cè)有效)
本文主要介紹了Docker拉取鏡像過(guò)慢或卡死的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07

