DockerFile 指令命令介紹
ARG
是唯一一個可用於FROM前的指令
1 示例
ARG CODE_VERSION=latest
FROM base:${CODE_VERSION}
CMD /code/run-app
FROM extras:${CODE_VERSION}
CMD /code/run-extras
2 示例
ARG VERSION=latest
FROM busybox:$VERSION
ARG VERSION
RUN echo $VERSION > image_version
FROM
制定所建立映象的基礎映象,如果本地不存在,則預設會去Docker Hub下載指定映象。格式為:
FROM <image>,或FROM <image>:<tag>,或FROM <image>@<digest>。
注意:任何Dockerfile中的第一條指令必須為FROM指令,並且,如果在同一個Dockerfile中建立多個映象,可以使用多個FROM指令(每個映象一次)。
MAINTAINER
指定維護者資訊,格式為MAINTAINER<name>
eg:
MAINTAINER [email protected]
該資訊會寫入生成映象的Author屬性域中
RUN
功能為執行指定的命令
RUN命令有兩種格式
1. RUN <command>
2. RUN ["executable", "param1", "param2"]
第一種後邊直接跟shell命令
-
在linux作業系統上預設 /bin/sh -c
-
在windows作業系統上預設 cmd /S /C
第二種是類似於函式呼叫。
可將executable理解成為可執行檔案,後面就是兩個引數。
兩種寫法比對:
-
RUN /bin/bash -c 'source $HOME/.bashrc; echo $HOME
-
RUN ["/bin/bash", "-c", "echo hello"]
注意:多行命令不要寫多個RUN,原因是Dockerfile中每一個指令都會建立一層.
多少個RUN就構建了多少層映象,會造成映象的臃腫、多層,不僅僅增加了構件部署的時間,還容易出錯。
RUN書寫時的換行符是\
CMD
功能為容器啟動時要執行的命令
語法有三種寫法
1. CMD ["executable","param1","param2"]
2. CMD ["param1","param2"]
3. CMD command param1 param2
第三種比較好理解了,就時shell這種執行方式和寫法
第一種和第二種其實都是可執行檔案加上引數的形式
舉例說明兩種寫法:
-
CMD [ "sh", "-c", "echo $HOME" ]
-
CMD [ "echo", "$HOME" ]
補充細節:這裡邊包括引數的一定要用雙引號,就是",不能是單引號。千萬不能寫成單引號。
原因是引數傳遞後,docker解析的是一個JSON array
RUN & CMD
不要把RUN和CMD搞混了。
RUN是構件容器時就執行的命令以及提交執行結果
CMD是容器啟動時執行的命令,在構件時並不執行,構件時緊緊指定了這個命令到底是個什麼樣子
注意:每個Dodckerfile 只能有一條CMD命令,如果指定了多條命令,只有最後一條會被執行。
LABEL
LABEL 指令用來指定生成映象的元資料標籤資訊。
格式為LABEL <KEY>=<VALUE> .....
eg:
LABEL version = "1.0"
LABEL description = "This text illustrates ...."
EXPOSE
宣告映象內服務所監聽的埠。
格式為EXPOSE <port > [<posrt> ... ]
eg:
EXPOSE 22 80 8443
注意:該指令只能宣告作用,並不會自動完成埠對映。
ENV
指定環境變數,在映象生成過程中會被後續RUN指令使用,在映象啟動的容器中也存在。
格式為:ENV<key><value>或ENV<key> = <value> ...
兩者的區別就是第一種是一次設定一個,第二種是一次設定多個
eg:
ENV name1 ping
ENV name2 on_ip
或者
ENV name1=ping name2=on_ip
ADD
如果把虛擬機器與容器想象成兩臺linux伺服器的話,那麼這個命令就類似於scp,只是scp需要加使用者名稱和密碼的許可權驗證,而ADD不用.
該命令將複製指定的<src>路徑下的內容到容器中的<dest>路徑下。
如以下寫法都是可以的:
-
ADD test relativeDir/
-
ADD test /relativeDir
-
ADD http://example.com/foobar /
注意:其中Dockerfile所在目錄的一個相對路徑(檔案或目錄),也可以是一個URL,還可以是tar檔案。支援正則表示式
COPY
看這個名字就知道,又是一個複製命令
語法如下:
1. COPY <src>... <dest>
2. COPY ["<src>",... "<dest>"]
與ADD的區別
COPY的<src>只能是本地檔案,其他用法一致
ENTRYPOINT
功能是啟動時的預設命令
語法如下:
1. ENTRYPOINT ["executable", "param1", "param2"]
2. ENTRYPOINT command param1 param2
如果從上到下看到這裡的話,那麼你應該對這兩種語法很熟悉啦。
第二種就是寫shell
第一種就是可執行檔案加引數
與CMD比較說明(這倆命令太像了,而且還可以配合使用):
1. 相同點:
-
只能寫一條,如果寫了多條,那麼只有最後一條生效
-
容器啟動時才執行,執行時機相同
2. 不同點:
-
ENTRYPOINT不會被執行的command覆蓋,而CMD則會被覆蓋
-
如果我們在Dockerfile種同時寫了ENTRYPOINT和CMD,並且CMD指令不是一個完整的可執行命令,那麼CMD指定的內容將會作為ENTRYPOINT的引數
如下:
FROM ubuntu
ENTRYPOINT ["top", "-b"]
CMD ["-c"]
-
如果我們在Dockerfile種同時寫了ENTRYPOINT和CMD,並且CMD是一個完整的指令,那麼它們兩個會互相覆蓋,誰在最後誰生效
如下:
FROM ubuntu
ENTRYPOINT ["top", "-b"]
CMD ls -al
那麼將執行ls -al ,top -b不會執行。
VOLUME
可實現掛載功能,可以將內地資料夾或者其他容器種得資料夾掛在到這個容器種
語法為:
VOLUME ["/data"]
說明:
["/data"]可以是一個JsonArray ,也可以是多個值。所以如下幾種寫法都是正確的
VOLUME ["/var/log/"]
VOLUME /var/log
VOLUME /var/log /var/db
一般的使用場景為需要持久化儲存資料時
容器使用的是AUFS,這種檔案系統不能持久化資料,當容器關閉後,所有的更改都會丟失。
所以當資料需要持久化時用這個命令。
USER
設定啟動容器的使用者,可以是使用者名稱或UID,所以,只有下面的兩種寫法是正確的
-
USER daemo
-
USER UID
注意:如果設定了容器以daemon使用者去執行,那麼RUN, CMD 和 ENTRYPOINT 都會以這個使用者去執行
WORKDIR
語法:
WORKDIR /path/to/workdir
設定工作目錄,對RUN,CMD,ENTRYPOINT,COPY,ADD生效。如果不存在則會建立,也可以設定多次。
如:
WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd
pwd執行的結果是/a/b/c
WORKDIR也可以解析環境變數
如:
ENV DIRPATH /path
WORKDIR $DIRPATH/$DIRNAME
RUN pwd
pwd的執行結果是/path/$DIRNAME
ONBUILD
語法:
ONBUILD [INSTRUCTION]
這個命令只對當前映象的子映象生效。
比如當前映象為A,在Dockerfile種新增:
ONBUILD RUN ls -al
這個 ls -al 命令不會在A映象構建或啟動的時候執行
此時有一個映象B是基於A映象構建的,那麼這個ls -al 命令會在B映象構建的時候被執行。
STOPSIGNAL
語法:
STOPSIGNAL signal
STOPSIGNAL命令是的作用是當容器推出時給系統傳送什麼樣的指令
HEALTHCHECK
容器健康狀況檢查命令
語法有兩種:
1. HEALTHCHECK [OPTIONS] CMD command
2. HEALTHCHECK NONE
第一個的功能是在容器內部執行一個命令來檢查容器的健康狀況
第二個的功能是在基礎映象中取消健康檢查命令
[OPTIONS]的選項支援以下三中選項:
--interval=DURATION 兩次檢查預設的時間間隔為30秒
--timeout=DURATION 健康檢查命令執行超時時長,預設30秒
--retries=N 當連續失敗指定次數後,則容器被認為是不健康的,狀態為unhealthy,預設次數是3
注意:
HEALTHCHECK命令只能出現一次,如果出現了多次,只有最後一個生效。
CMD後邊的命令的返回值決定了本次健康檢查是否成功,具體的返回值如下:
0: success - 表示容器是健康的
1: unhealthy - 表示容器已經不能工作了
2: reserved - 保留值
例子:
HEALTHCHECK --interval=5m --timeout=3s \
CMD curl -f http://localhost/ || exit 1
健康檢查命令是:curl -f http://localhost/ || exit 1
兩次檢查的間隔時間是5秒
命令超時時間為3秒