共計(jì) 4081 個(gè)字符,預(yù)計(jì)需要花費(fèi) 11 分鐘才能閱讀完成。
這篇文章主要講解了“Dockerfile 基本結(jié)構(gòu)是什么”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著丸趣 TV 小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Dockerfile 基本結(jié)構(gòu)是什么”吧!
## 基本結(jié)構(gòu)
Oockerfile 由一行行語句行組成,支持以__#__開頭的注釋行。
通常一個(gè) Dockerfile 文件包含四個(gè)組成部分:基礎(chǔ)鏡像信息、維護(hù)者信息、鏡像操作指令和容器啟動(dòng)時(shí)執(zhí)行的命令。
比如,下面這個(gè)簡(jiǎn)單的示例:
# 鏡像基礎(chǔ)信息
# This dockerfile uses the ubuntu image
# VERSION 2 - EDITION 1
# Author: docker_user
# Command format: Instruction [arguments / command] ..
# Base image to use, this must be set as the first line
FROM ubuntu
#維護(hù)者信息
# Maintainer: docker_user docker_user at email.com (@docker_user)
MAINTAINER docker_user docker_user@email.com
#鏡像操作指令
# Commands to update the image
RUN echo deb http://archive.ubuntu.com/ubuntu/ raring main universe /etc/apt/sources.list
RUN apt-get update apt-get install -y nginx
RUN echo \ndaemon off; /etc/nginx/nginx.conf
# 容器啟動(dòng)時(shí)執(zhí)行
# Commands when creating a new container
CMD /usr/sbin/nginx
每個(gè) Dockerifle 文件必須首先指明基礎(chǔ)鏡像信息,接下來推薦說明維護(hù)者信息,維護(hù)者信息不是必須的。
## 指令
### 注釋:
使用 # 來注釋
示例:
# Memcached
# VERSION 1.0
# use the ubuntu base image provided by dotCloud
FROM ubuntu
# make sure the package repository is up to date
RUN echo deb http://archive.ubuntu.com/ubuntu precise main universe /etc/apt/sources.list
RUN apt-get update
# install memcached
RUN apt-get install -y memcached
###FROM:
FROM image
或者
FROM image
: tag
第一條指令必須為 FROM 指令。并且,如果在同一個(gè) Dockerfile 中創(chuàng)建多個(gè)鏡像時(shí),可以使用多個(gè) FROM 指令(每個(gè)鏡像一次)。
示例:
FROM ubuntu
如果指定的鏡像本地沒有,Dokcer 會(huì)自動(dòng)從倉庫注冊(cè)服務(wù)器下載指定的鏡像;如果沒有指定__tag__,則默認(rèn) tag 是__latest__,如果都沒有則會(huì)報(bào)錯(cuò)。
###MAINTAINER:
MAINTAINER name
該指令用于指定維護(hù)者信息。比如姓名,聯(lián)系方式等。
示例:
MAINTAINER Anoxia windorman@gmaillcom
###RUN:
RUN command (the command is run in a shell - `/bin/sh -c`)
或者
RUN [executable , param1 , param2 ...] (exec form)
RUN 命令等價(jià)于:
docker run image command
docker commit container_id
示例:
RUN apt-get update
RUN apt-get -y install apache2
###CMD:
CMD [executable , param1 , param2]
使用 exec 執(zhí)行,推薦方式;
或者
CMD command param1 param2
在 /bin/sh 中執(zhí)行,提供給需要交互的應(yīng)用;
或者
CMD [param1 , param2]
提供給 ENTRYPOINT 的默認(rèn)參數(shù);
指定啟動(dòng)容器時(shí)執(zhí)行的命令,每個(gè) Dockerfile 只能有一條__CMD__命令。如果指定了多條命令,只有最后一條會(huì)被執(zhí)行。
如果用戶啟動(dòng)容器時(shí)候指定了運(yùn)行的命令,則會(huì)覆蓋掉 CMD 指定的命令。
示例:
CMD [/usr/sbin/apachectl , -D , FOREGROUND]
###EXPOSE:
EXPOSE port [port ...]
告訴 Docker 服務(wù)端容器暴露的端口號(hào),共互聯(lián)系統(tǒng)使用。在啟動(dòng)容器時(shí)需要通過 -P,Docker 主機(jī)會(huì)自動(dòng)分配一個(gè)端口轉(zhuǎn)發(fā)到指定的端口。
示例:
EXPOSE 11211
###ENV:
ENV key value
指定一個(gè)環(huán)境變量,會(huì)被后續(xù) RUN 指令使用,并在容器運(yùn)行時(shí)保持。
示例:
ENV PG_MAJOR 9.3
ENV PG_VERSION 9.3.4
RUN curl -SL http://example.com/postgres-$PG_VERSION.tar.xz | tar -xJC /usr/src/postgress …
ENV PATH /usr/local/postgres-$PG_MAJOR/bin:$PATH
使用此 ENV 生成的 image 新建 container,可以通過 docker inspect 看到這個(gè)環(huán)境變量:
root@tankywoo-docker:~# docker inspect 49bfc7a9817f
Env : [
name=tanky ,
HOME=/ ,
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
...
里面的 name=tanky 就是設(shè)置的。也可以通過在 docker run 時(shí)設(shè)置或修改環(huán)境變量:
docker run -i -t --env name= tanky ubuntu:newtest /bin/bash
###ADD:
ADD src dest
該命令將復(fù)制指定的 src 到容器中的 dest。其中 src 可以是 Dockerfile 所在目錄的一個(gè)相對(duì)路徑;也可以是一個(gè) URL;還可以是一個(gè) tar 文件(自動(dòng)解壓為目錄)。
示例:
ADD ./scripts/start.sh /start.sh
###COPY:
COPY src dest
復(fù)制本地主機(jī)的 src(為 Dockerfile 所在目錄的相對(duì)路徑)到容器中的 dest。當(dāng)使用本地目錄為源目錄時(shí),推薦使用 COPY。
示例:
ADD ./scripts/start.sh /start.sh
###ENTRYPOINT:
ENTRYPOINT [executable , param1 , param2]
或者:
ENTRYPOINT command param1 param2(shell 中執(zhí)行)
配置容器啟動(dòng)后執(zhí)行的命令,并且不可被 docker run 提供的參數(shù)覆蓋。每個(gè) Dockerfile 中只能有一個(gè) ENTRYPOINT,當(dāng)指定多個(gè)時(shí),只有最后一個(gè)起效。
示例:
ENTRYPOINT [echo , Whale you be my container]
###VOLUME:
VOLUME [mountpoint]
創(chuàng)建一個(gè)可以從本地主機(jī)或其他容器掛載的掛載點(diǎn),一般用來存放數(shù)據(jù)庫和需要保持的數(shù)據(jù)等。
示例:
VOLUME [/data]
###USER:
USER daemon
指定運(yùn)行容器時(shí)的用戶名或 UID,后續(xù)的 RUN 也會(huì)使用指定用戶。
當(dāng)服務(wù)不需要管理員權(quán)限時(shí),可以通過該命令指定運(yùn)行用戶。并且可以在之前創(chuàng)建所需要的用戶,例如
RUN groupadd -r postgres useradd -r -g postgres postgres
USER postgres
要臨時(shí)獲取管理員權(quán)限可以使用 gosu,而不推薦 sudo。
###WORKDIR
WORKDIR /path/to/workdir
為后續(xù)的 RUN、CMD、ENTRYPOINT 指令配置工作目錄。可以使用多個(gè) WORKDIR 指令,后續(xù)命令如果參數(shù)是相對(duì)路徑,則會(huì)基于之前命令指定的路徑。
示例:
WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd
則最終路徑為 /a/b/c。
###ONBUILD
ONBUILD [INSTRUCTION]
配置當(dāng)所創(chuàng)建的鏡像作為其它新創(chuàng)建鏡像的基礎(chǔ)鏡像時(shí),所執(zhí)行的操作指令。
例如,Dockerfile 使用如下的內(nèi)容創(chuàng)建了鏡像 image-A。
[...]
ONBUILD ADD . /app/src
ONBUILD RUN /usr/local/bin/python-build --dir /app/src
[...]
如果基于 image-A 創(chuàng)建新的鏡像時(shí),新的 Dockerfile 中使用 FROM image-A 指定基礎(chǔ)鏡像時(shí),會(huì)自動(dòng)執(zhí)行 ONBUILD 指令內(nèi)容,等價(jià)于在后面添加了兩條指令。
FROM image-A
#Automatically run the following
ADD . /app/src
RUN /usr/local/bin/python-build --dir /app/src
使用 ONBUILD 指令的鏡像,推薦在標(biāo)簽中注明,例如 ruby:1.9-onbuild。
感謝各位的閱讀,以上就是“Dockerfile 基本結(jié)構(gòu)是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì) Dockerfile 基本結(jié)構(gòu)是什么這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是丸趣 TV,丸趣 TV 小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!