我建議這個命令放在Dockerfile的起始部分,雖然理論上它可以放置于Dockerfile的任意位置。這個命令用于聲明作者,并應該放在FROM的后面。

# MAINTAINER [name] [email]
MAINTAINER authors_name "hongtu1993@sina.cn"

FROM

FROM命令可能是最重要的Dockerfile命令。改命令定義了使用哪個基礎鏡像啟動構建流程。基礎鏡像可以為任意鏡 像。如果基礎鏡像沒有被發現,Docker將試圖從Docker image index來查找該鏡像。FROM命令必須是Dockerfile的首個命令。

# FROM [image name]

FROM ubuntu

ADD

ADD命令有兩個參數,源和目標。它的基本作用是從源系統的文件系統上復制文件到目標容器的文件系統。如果源是一個URL,那該URL的內容將被下載并復制到容器中。

# ADD [source directory or URL] [destination directory]

ADD /my_app_folder /my_app_folder

RUN

RUN命令是Dockerfile執行命令的核心部分。它接受命令作為參數并用于創建鏡像。不像CMD命令,RUN命令用于創建鏡像(在之前commit的層之上形成新的層)。

# RUN [command]

RUN apt-get update

CMD

和RUN命令相似,CMD可以用于執行特定的命令。和RUN不同的是,這些命令不是在鏡像構建的過程中執行的,而是在用鏡像構建容器后被調用。

# CMD application "argument", "argument", ..

CMD "echo" "Hello Mao!"

ENTRYPOINT

ENTRYPOINT幫助你配置一個容器使之可執行化,如果你結合CMD命令和ENTRYPOINT命令,你可以從CMD命令中移除“application”而僅僅保留參數,參數將傳遞給ENTRYPOINT命令。

# Usage: ENTRYPOINT application "argument", "argument", ..
# Remember: arguments are optional. They can be provided by CMD
# or during the creation of a container.
ENTRYPOINT echo

# Usage example with CMD:
# Arguments set with CMD can be overridden during *run*
CMD "Hello docker!"
ENTRYPOINT echo

ENV

ENV命令用于設置環境變量。這些變量以”key=value”的形式存在,并可以在容器內被腳本或者程序調用。這個機制給在容器中運行應用帶來了極大的便利。

# ENV key value

ENV SERVER_WORKS 4

USER

USER命令用于設置運行容器的UID。

# USER [UID]

USER 751

VOLUME

VOLUME命令用于讓你的容器訪問宿主機上的目錄。

# VOLUME ["/dir_1", "/dir_2" ..]

VOLUME ["/my_files"]

WORKDIR

WORKDIR命令用于設置CMD指明的命令的運行目錄。

# WORKDIR /path

WORKDIR ~/

EXPOSE

EXPOSE指令用來告訴Docker這個容器在運行時會監聽哪些端口,Docker在連接不同的容器(使用–link參數)時使用這些信息;
兩個Docker的核心概念是可重復和可移植。鏡像應該可以運行在任何主機上并且運行盡可能多的次數。在 Dockerfile中你有能力映射私有和公有端口,但是你永遠不要通過Dockerfile映射公有端口。通過映射公有端口到主機上,你將只能運行一個容器化應用程序實例。(譯者注:運行多個端口不就沖突啦)

# EXPOSE [port]

# private and public mapping
EXPOSE 80:8080

# private only
EXPOSE 80

最后我們來個簡單的示例吧

使用Dockerfile自動構建Nginx容器

因為我們命令Docker用當前目錄的Nginx的配置文件替換默認的配置文件,我們要保證這個新的配置文件存在。在Dockerfile存在的目錄下,創建nginx.conf:

sudo nano nginx.conf

然后用下述內容替換原有內容:

worker_processes 1;
events { worker_connections 1024; }
http {
   sendfile on;
   server {
     listen 80;
     location / {
       proxy_pass http://httpstat.us/;
       proxy_set_header X-Real-IP $remote_addr;
     }
   }
}

讓我們保存nginx.conf。之后我們就可以用Dockerfile和配置文件來構建鏡像。

贊(0)
聲明:本網站發布的內容(圖片、視頻和文字)以原創、轉載和分享網絡內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。郵箱:3140448839@qq.com。本站原創內容未經允許不得轉載,或轉載時需注明出處:三五互聯知識庫 » Dockerfile命令介紹及用例解析

登錄

找回密碼

注冊

主站蜘蛛池模板: 在线观看特色大片免费视频| 亚洲第一尤物视频在线观看导航| 亚洲中文字幕日产无码成人片| 精品国产自在久久现线拍| 正在播放肥臀熟妇在线视频| 国产国产精品人体在线视| 99久热在线精品视频| 欧美一区二区三区成人久久片| 蜜臀av无码一区二区三区| 国产人妻一区二区三区四区五区六| 国产av亚洲精品ai换脸电影| 亚洲午夜亚洲精品国产成人| 中文字幕一卡二卡三卡| 久久久精品人妻一区二区三区| 国产初高中生粉嫩无套第一次| 久久国产乱子精品免费女| 亚洲国产精品久久久久婷婷图片| 国产精品久久国产精麻豆| 国产av亚洲精品ai换脸电影| 久久精品国产亚洲av亚| 无码精品人妻一区二区三区中| 久久国产成人高清精品亚洲| 九九热视频在线观看精品| 欧洲免费一区二区三区视频| 动漫AV纯肉无码AV电影网 | 国产精品视频一区不卡| 少妇特黄a一区二区三区| 欧美大bbbb流白水| 亚洲精品综合一区二区三区在线| 全免费A级毛片免费看无码| 在线午夜精品自拍小视频| 人妻人人做人碰人人添| 日本亚洲欧洲免费无线码| 久久综合色天天久久综合图片| 精品中文人妻中文字幕| 国产91精品一区二区麻豆| 欧美成人免费一区二区三区视频| 色综合一本到久久亚洲91| 任你躁国产自任一区二区三区| 太仓市| 亚洲综合一区二区三区|