Dockerfile 文件全面詳解
原文鏈接:https://zhuanlan.zhihu.com/p/387855002
${variable:-word} 表示如果 variable 設(shè)置,則結(jié)果將是該值。如果 variable 未設(shè)置,word 則將是結(jié)果。
${variable:+word} 表示如果 variable 設(shè)置則為 word 結(jié)果,否則為空字符串。
FROM [--platform=<platform>] <image> [AS <name>]
FROM [--platform=<platform>] <image>[:<tag>] [AS <name>]
FROM [--platform=<platform>] <image>[@<digest>] [AS <name>]
單個(gè) Dockfile 可以多次出現(xiàn) FROM,以使用之前的構(gòu)建階段作為另一個(gè)構(gòu)建階段的依賴(lài)項(xiàng)
AS name 表示為構(gòu)建階段命名,在后續(xù) FROM 和 COPY --from=<name> 說(shuō)明中可以使用這個(gè)名詞,引用此階段構(gòu)建的映像
digest 其實(shí)就是就是根據(jù)鏡像內(nèi)容產(chǎn)生的一個(gè) ID,只要鏡像的內(nèi)容不變 digest 也不會(huì)變
tag 或 digest 值是可選的。如果您省略其中任何一個(gè),構(gòu)建器默認(rèn)使用一個(gè) latest 標(biāo)簽。如果找不到該 tag 值,構(gòu)建器將返回錯(cuò)誤。
--platform 標(biāo)志可用于在 FROM 引用多平臺(tái)鏡像的情況下指定平臺(tái)。例如,linux/amd64、linux/arm64、 或 windows/amd64。
RUN /bin/bash -c 'source $HOME/.bashrc; \
echo $HOME'
RUN<command>(shell 形式,命令在 shell 中運(yùn)行,默認(rèn) /bin/sh -c 在 Linux 或 cmd /S /CWindows 上)
RUN ["executable", "param1", "param2"](執(zhí)行形式)
可以使用 \(反斜杠)將單個(gè) RUN 指令延續(xù)到下一行
RUN 在下一次構(gòu)建期間,指令緩存不會(huì)自動(dòng)失效。可以使用 --no-cache 標(biāo)志使指令緩存無(wú)效
Dockerfile 的指令每執(zhí)行一次都會(huì)在 Docker 上新建一層。所以過(guò)多無(wú)意義的層,會(huì)造成鏡像膨脹過(guò)大,可以使用 && 符號(hào)連接命令,這樣執(zhí)行后,只會(huì)創(chuàng)建 1 層鏡像
FROM ubuntu
CMD ["/usr/bin/wc","--help"]
CMD ["executable","param1","param2"] 使用 exec 執(zhí)行,推薦方式;
CMD command param1 param2 在 /bin/sh 中執(zhí)行,提供給需要交互的應(yīng)用;
CMD ["param1","param2"] 提供給 ENTRYPOINT 的默認(rèn)參數(shù)。
LABEL multi.label1="value1" \
multi.label2="value2" \
other="value3"
EXPOSE <port> [<port>/<protocol>...]
EXPOSE 80/udp
ENV <key>=<value> ...
RUN DEBIAN_FRONTEND=noninteractive apt-get update && apt-get install -y ...
ARG DEBIAN_FRONTEND=noninteractive
RUN apt-get update && apt-get install -y ...
ADD hom* /mydir/
ADD hom?.txt /mydir/
ENTRYPOINT ["executable", "param1", "param2"]
ENTRYPOINT command param1 param2
<ENTRYPOINT> <CMD>
VOLUME ["/var/log/"]
VOLUME /var/log
避免重要的數(shù)據(jù),因容器重啟而丟失
避免容器不斷變大
ARG <name>[=<default value>]
HTTP_PROXY
http_proxy
HTTPS_PROXY
https_proxy
FTP_PROXY
ftp_proxy
NO_PROXY
no_proxy
docker build --build-arg HTTPS_PROXY=https://my-proxy.example.com .
ONBUILD ADD . /app/src
ONBUILD RUN /usr/local/bin/python-build --dir /app/src
STOPSIGNAL signal
HEALTHCHECK [OPTIONS] CMD command(通過(guò)在容器內(nèi)運(yùn)行命令來(lái)檢查容器健康狀況)
HEALTHCHECK NONE(禁用從基礎(chǔ)鏡像繼承的任何健康檢查)
SHELL ["executable", "parameters"]
WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd
ENV DIRPATH=/path
WORKDIR $DIRPATH/$DIRNAME
RUN pwd
USER <user>[:<group>]
USER <UID>[:<GID>]
- END -
推薦閱讀 Kubernetes 企業(yè)運(yùn)維進(jìn)階實(shí)戰(zhàn) Linux服務(wù)器訪問(wèn)慢,通過(guò)這些工具可以快速找出系統(tǒng)瓶頸! 6 張圖帶你搞懂 CI/CD 流水線(xiàn) Nginx配置中一個(gè)不起眼字符"/"的巨大作用,失之毫厘謬以千里 企業(yè)級(jí)日志系統(tǒng) ELK 原理與實(shí)踐詳細(xì)介紹 Ceph 常見(jiàn)故障排查筆記總結(jié) 編寫(xiě) Dockerfile 最佳實(shí)踐 運(yùn)維工程師不得不看的經(jīng)驗(yàn)教訓(xùn)和注意事項(xiàng) 終于搞懂了服務(wù)器為啥產(chǎn)生大量的TIME_WAIT! Kubernetes 網(wǎng)絡(luò)方案之炫酷的 Cilium 這些 K8S 日常故障處理集錦,運(yùn)維請(qǐng)收藏~ 12年資深運(yùn)維老司機(jī)的成長(zhǎng)感悟 搭建一套完整的企業(yè)級(jí) K8s 集群(kubeadm方式)
點(diǎn)亮,服務(wù)器三年不宕機(jī)



