Dockerfile文件詳解
什么是dockerfile?
Dockerfile是一個(gè)包含用于組合映像的命令的文本文檔??梢允褂迷诿钚兄姓{(diào)用任何命令。 Docker通過讀取Dockerfile
中的指令自動(dòng)生成映像。
docker build
命令用于從Dockerfile構(gòu)建映像。可以在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文件說明
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ǎ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ǎ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非常類似,不同的是通過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ù)之間通過空格分隔。推薦將所有的元數(shù)據(jù)通過一條LABEL指令指定,以免生成過多的中間鏡像。
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>中包含空格,可以使用\來進(jìn)行轉(zhuǎn)義,也可以通過""來進(jìn)行標(biāo)示;另外,反斜線也可以用于續(xù)行 #示例: ENV myName John Doe ENV myDog Rex The Dog ENV myCat=fluffy
EXPOSE
指定于外界交互的端口
#格式: EXPOSE <port> [<port>...] #示例: EXPOSE 80 443 EXPOSE 8080 EXPOSE 11211/tcp 11211/udp
注:EXPOSE并不會(huì)讓容器的端口訪問到主機(jī)。要使其可訪問,需要在docker run
運(yùn)行容器時(shí)通過-p來發(fā)布這些端口,或通過-P
參數(shù)來發(fā)布EXPOSE導(dǎo)出的所有端口
VOLUME
用于指定持久化目錄
#格式: VOLUME ["/path/to/dir"] #示例: VOLUME ["/data"] VOLUME ["/var/www", "/var/log/apache2", "/etc/apache2"
注:一個(gè)卷可以存在于一個(gè)或多個(gè)容器的指定目錄,該目錄可以繞過聯(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)
注:通過WORKDIR設(shè)置工作目錄后,Dockerfile中其后的命令RUN、CMD、ENTRYPOINT、ADD、COPY等命令都會(huì)在該目錄下執(zhí)行。在使用docker run運(yùn)行容器時(shí),可以通過-w參數(shù)覆蓋構(gòu)建時(shí)所設(shè)置的工作目錄。
USER
指定運(yùn)行容器時(shí)的用戶名或 UID,后續(xù)的 RUN 也會(huì)使用指定用戶。使用USER指定用戶時(shí),可以使用用戶名、UID或GID,或是兩者的組合。當(dāng)服務(wù)不需要管理員權(quán)限時(shí),可以通過該命令指定運(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)建完成后,通過docker run運(yùn)行容器時(shí),可以通過-u參數(shù)來覆蓋所指定的用戶。
ARG
用于指定傳遞給構(gòu)建運(yùn)行時(shí)的變量
#格式: ARG <name>[=<default value>] #示例: ARG site ARG build_user=www
ONBUILD
用于設(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)前目錄下,拷過去會(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的問題
- Python?Web?App開發(fā)Dockerfiles編寫示例
- docker通過Dockerfile構(gòu)建mysql鏡像的方法
- 如何使用?Dockerfile?創(chuàng)建一個(gè)簡(jiǎn)單容器
- dockerfile指令構(gòu)建docker鏡像的示例代碼
- 使用Dockerfile實(shí)現(xiàn)數(shù)據(jù)卷的掛載問題(推薦)
- 利用Dockerfile優(yōu)化Nestjs構(gòu)建鏡像大小詳情
相關(guān)文章
Centos8安裝docker報(bào)錯(cuò)(錯(cuò)誤提示:All?mirrors?were?tried)的問題
最近總是遇到“All?mirrors?were?tried”的報(bào)錯(cuò)信息,沒辦法,就rm?-rf?/etc/yum.repos.d/*?全部!刪了,下面小編通過本文給大家介紹下Centos8安裝docker報(bào)錯(cuò)(錯(cuò)誤提示:All?mirrors?were?tried)的問題及解決過程,感興趣的朋友一起看看吧2022-03-03SQL?Server?簡(jiǎn)介與?Docker?Compose?部署SQL?Server?容器
SQL?Server?是一個(gè)功能強(qiáng)大的關(guān)系型數(shù)據(jù)庫管理系統(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++程序的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10安裝Docker Desktop報(bào)錯(cuò)WSL 2 installation is incomplete的問題(解決報(bào)錯(cuò))
這篇文章主要介紹了安裝Docker Desktop報(bào)錯(cuò)WSL 2 installation is incomplete的問題,解決方法很簡(jiǎn)單只需我們自己手動(dòng)更新一下,我們根據(jù)提示去微軟官網(wǎng)下載最新版的wsl2安裝后即可正常打開,需要的朋友可以參考下2021-06-06Docker部署Rabbitmq容器實(shí)現(xiàn)過程解析
這篇文章主要介紹了Docker部署Rabbitmq容器實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11Docker拉取鏡像過慢或卡死的解決方法(親測(cè)有效)
本文主要介紹了Docker拉取鏡像過慢或卡死的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07