Dockerfile 簡單使用
先來編寫一個最簡單的 Dockerfile。
- 例如:
FROM nginx
RUN echo '<h1>使用Dockerfile構建鏡像</h1>' > /usr/share/nginx/html/index.html
該 Dockerfile 非常簡單,其中的 FORM 、 RUN 都是 Dockerfile 的指令。
FROM 指令用于指定基礎鏡像 RUN 指令用于執行命令
2. 在 Dockerfile 所在路徑執行一下命令構建鏡像:
docker build -t nginx:my .
其中,命令最后的點(.)用于路徑參數傳遞,表示當前路徑。
- 執行以下命令,即可使用該鏡像啟動一個 Docker容器。
docker run -d -p 92:80 nginx:my
- 訪問查看到效果(頁面是因為編碼問題)。
從本例不難看出 Dockerfile的強大。僅僅編寫了兩行代碼,就修改了原始鏡像的行為。不僅如此,通過 Dockerfile,還可直觀地看到修改鏡像的具體過程。
除了使用Dockerfile構建鏡像,也可手工制作 Docker鏡像,但這種方式煩瑣效率低,一般不適合生產。
Dockerfile 常用指令
在前面的例子中,提到了FORM、RUN指令。事實上, Dockerfile有十多個指令,指令的一般格式為:指令名稱參數。
- ADD復制文件
ADD 指令用于復制文件,格式為:
ADD <src>... <dest>
ADD ["<srv>"... "<dest>"]
從src目錄復制文件到容器的dest。其中src可以是 Dockerfile所在目錄的相對路徑,也可以是一個URL,還可以是一個壓縮包。
注意:
1、src必須在構建的上下文內,不能使用例如:ADD ../somethine/something這樣的命令,因為 docker bui1d命令首先會將上下文路徑和其子目錄發送到 docker daemon。
2、如果src是一個URL,同時dest不以斜杠結尾,dest將會被視為文件,src對應內容文件將會被下載到 dest。
3、如果src是一個URL,同時dest以斜杠結尾,dest將被視為目錄,src對應內容將會被下載到dest目錄。
4、如果 src 是一個目錄,那么整個目錄下的內容將會被復制,包括文件系統元數據。
5、如果文件是可識別的壓縮包格式,則 doclcer 會自動解壓。
示例:ADD wzq-swagger-mng.jar app.jar
- ARG 設置構建參數
ARG 指令用于設置構建參數,類似于 ENV。和 ARG 不同的是, ARG 設置的是構建時的環境變量,在容器運行時是不會存在這些變量的。
格式為: ARG <name> [<default value>]。
示例: ARG user=Jacob - CMD 容器啟動命令
CMD 指令用于為執行容器提供默認值。每個 Dockerfile 只有一個 CMD 命令,如果指定了多個 CMD 命令,那么只有最后一條會被執行,如果啟動容器時指定了運行的命令,則會覆蓋掉 CMD 指定的命令。
支持 3 種格式:
CMD ["executable","paraml","param2"] (推薦使用)
CMD ["param1","param2"](為 ENT 盯 PoINT 指令提供預設參數)
CMD command param1 param2 (在 shell 中執行)
示例: CMD echo " This 15 a test ." | wc - - COPY 復制文件
復制文件,格式為:
COPY <src>... <dest>
COPY ["<src>",... "<dest>"]
復制本地的 src 到容器的 dest 。COPY 指令和 ADD 指塵類似, COPY 不支持 URL 和 壓縮包。 - ENTRYPOINT 人口點
格式為:
ENTRYPOINT ["executable","param1";"param2"]
ENTRYPOINT command param1 param2
ENTRYPOINT 和 CMD指令目的是一樣的,都是指定 Docker 容器啟動時執行的命令,可多次設置,但只有最后一個有效。 - ENV 設置環境變量
ENV 指令用于設置環境變量,格式為:
ENV <key> <value>
ENV <key>=<value>
示例: ENV JAVA_HOME /path/to/java - EXPOSE聲明暴露的端口
EXPOSE 指令用于聲明在運行時容器提供服務的端口,格式為: EXPOSE <port> [<port>...]。
需要注意的是,這只是一個聲明,運行時并不會因為該聲明就打開相應端口。該指令的作用主要是幫助鏡像使用者理解該鏡像服務的守護端口;其次是當運行時使用隨機映射時,會自動映射 EXP0SE 的端口。
示例:
- 聲明暴露一個端口示例 EXPOSE port1
- 相應的運行容器使用的命令 docker run -p port1 image
- 也可使用一 P 選項啟動 docker run -P image
- 聲明暴露多個端口示例 EXPOSE port1 port2 port3
- 相應的運行容器使用的命令 docker run -p port1 -p port2 -p port3 image
- 也可指定需要映射到宿主機器上的端口號 docker run -p host_port1:port1 -p host_port2:port2 -p host_port3:port3 image
- FROM 指定基礎鏡像
使用 FORM 指令指定基礎鏡像,FORM 指令有點像 Java 里面的 extends 關鍵字。需要注意的是,FROM 指令必須指定且需要寫在其他指令之前。 FORM 指令后的所有指令都依賴于該指令所指定的鏡像。
支持 3 種格式:
FROM <image>
FROM <image>:<tag>
FROM <image>@<digest> - LABEL 為鏡像添加元數據
LABEL 指令用于為鏡像添加元數據。
格式為:LABLE <key>=<volue> <key>=<volue> <key>=<volue> ...。
使用“ " ”和“ \ ”轉換命令行。
示例:
LABEL "com.example.vendor"="ACME Incorporated"
LABEL com.example.label-with-value="foo"
LABEL version="1.0"
LABLE description="This text illustrates that label-values can span multlple lines." - MAINTAINER 指定維護者的信息
MAINTAINER 指令用于指定維護者的信息,用于為 DOCkerfile 署名。格式為: MAINTAINR <name>。
示例:
MAINTAINER Jacob<596766829@qq.com> - RUN 執行命令
該指令支持兩種格式:
RUN <Command>
RUN ["executable","param1","param2"]
UuN <command>在 shell 終端中運行,在 Linux 中默認是/bin/Sh -C ,在 Windows 中是 cmd /s /c,使用這種格式,就像直接在命令行中輸人命令一樣。 RUN ["executable","param1","param2"] 使用 exec 執行,這種方式類似于函數調用。指定其他終端可以通過該方式操作,例如: RUN ["/bin/bash","-c","echo hello"] ,該方式必須使用雙引號”而不能使用單引號',因為該方式會被轉換成一個 JsON 數組。 - USER 設置用戶
該指令用于設置啟動鏡像時的用戶或者 UID ,寫在該指令后的 RUN 、 CMD 以及 ENTRYPOINT 指令都將使用該用戶執行命令。
格式為:USER 用戶名。
示例: USER Jacob - VOLUME 指定掛載點
該指令使容器中的一個目錄具有持久化存儲的功能,該目錄可被容器本身使用,也可共享給其他容器。當容器中的應用有持久化數據的需求時可以在 Dockerfile 中使用該指令。格式為:VOLUME ["data"。
示例: VOLUME /data - WORKDIR 指定工作目錄
格式為: WORKOIR /path/to/workdir。
切換目錄指令,類似于 cd 命令,寫在該指令后的 RUN , CMD 以及 ENTRYPOINT 指令都將該目錄作為當前目錄,并執行相應的命令。 - 其他
Dockerfile 還有一些其他的指令,例如 STOPSINGAL、HEALTHcHECK、SHELL 等。有興趣的可前往 https://docs.docker.com/engine/reference/builder/進行擴展閱讀。
使用 Dockerfile 構建 Docker 鏡像
- 準備工作
準備一個Jar包,本次使用的Jar包是springboot整合swagger。 - 使用Dockerfile 構建 Docker 鏡像
創建 Dockerfile 文件,并添加一下內容
#指定鏡像
FROM java:8
#將本地文件夾掛載到當前容器
VOLUME /tmp
#復制文件到容器
ADD wzq-swagger-mng.jar app.jar
RUN bash -c 'touch /app.jar'
#聲明需要暴露的端口
EXPOSE 10086
#配置容器啟動后需要執行的命令
ENTRYPOINT ["java","-Djava.security.edg=file:/dev/.urandom","-jar","/app.jar"]
- 使用 docker build 命令構建鏡像
docker build -t itouch/wzq-swagger-mng .
4. 啟動鏡像
docker run -d -p 10086:10086 itouch/wzq-swagger-mng
- 測試