我建議這個命令放在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命令介紹及用例解析

登錄

找回密碼

注冊

主站蜘蛛池模板: 国产美女久久久亚洲综合| 四虎永久在线精品无码视频| 狠狠色丁香婷婷综合尤物| 男女爽爽无遮挡午夜视频| 国产精品自在线拍国产手机版| 樱桃视频影院在线播放| 国产在线播放专区av| 老子午夜精品888无码不卡| 91精品一区二区蜜桃| 尤物蜜芽国产成人精品区| 部精品久久久久久久久| h无码精品动漫在线观看| 亚洲午夜精品久久久久久抢| 欧美成年黄网站色视频| 达尔| 99人中文字幕亚洲区三| 精品国产亚洲一区二区三区| 蜜臀在线播放一区在线播放| 四虎国产精品永久在线| 国产日韩精品免费二三氏| 绥中县| 女同精品女同系列在线观看| 久爱www人成免费网站| 欧美老少配性行为| 成人av天堂男人资源站| 99久久婷婷国产综合精品| 成人精品一区日本无码网| 乱女伦露脸对白在线播放| 日韩成人高精品一区二区| 在线一区二区中文字幕| 2019国产精品青青草原| 亚洲春色在线视频| 2020国产欧洲精品网站| 天啦噜国产精品亚洲精品| 国产精品高清中文字幕| 亚洲中文字幕国产精品| 免费视频爱爱太爽了| 色综合久久中文综合久久激情| 丁香五月天综合缴情网| 国产高跟黑色丝袜在线| 精品黄色av一区二区三区|