成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

IT工程師都需要掌握的容器技術之Dockerfile

開發 前端
今天我們繼續來學習Docker技術,本篇文章主要介紹Dockerfile,Dockerffile是一個文本文件,Docker通過讀取Dockerfile文件來自動構建鏡像。

 今天我們繼續來學習Docker技術,本篇文章主要介紹Dockerfile,Dockerffile是一個文本文件,Docker通過讀取Dockerfile文件來自動構建鏡像。

下面就由成哥來介紹Dockerfile的語法及使用方法吧!

01 Dockerfile概述

Dockerfile相當于一個文檔,用戶可以基于dockerfile生產新的容器。Dockerfile僅僅是用來制作鏡像的源碼文件,是構建容器過程中的指令,docker能夠讀取dockerfile的指令進行自動構建容器,基于dockerfile制作鏡像,每一個指令都會創建一個鏡像層,即鏡像層是多層疊加的,鏡像層數越多,效率越低。所以創建鏡像時盡量通過越少的指令完成需要的動作。Docker通過dockerfile進行build及build后的鏡像運行流程邏輯如下圖所示。

 

IT工程師都需要掌握的容器技術之Dockerfile

 

02 Dockerfile的編寫

(1) 上下文

上下文就是指我們build Docker鏡像時Dockerfile文件所在的目錄,構建鏡像是由Docker守護程序而不是CLI運行的,該過程的第一件事是將 Dockerfile 文件所在目錄下的所有內容遞歸的發送到守護進程。所以在大多數情況下,最好是創建一個新的目錄,在其中保存 Dockerfile,并在其中添加構建 Dockerfile 所需的文件。

現在我們就在系統中創建一個空目錄以便下面Dockerfile文件的創建及后面的鏡像構建

 

IT工程師都需要掌握的容器技術之Dockerfile

 

(2) Dockerfile格式

Dockerfile的語法格式如下所示:

 

  1. 1. # 格式為語法+參數   
  2. 2. INSTRUCTION arguments   

 

該指令不區分大小寫。但是,約定將它們大寫,以便更輕松地將它們與參數區分開。Dockerfile按順序運行指令。

(3) Dockerfile常用指令

1)FROM

一個Dockerfile 必須以開始FROM的指令。使用FROM指令指定一個基礎鏡像,后續指令將在此鏡像的基礎上運行,在一個Dockerfile文件中FROM可以出現多次,下面我們來看看FROM的語法格式

  1. 1. FROM [--platform=<platform>] <image> [AS <name>]   

我們創建一個Dockerfile文件,其中FROM指定以centos為基礎鏡像

 

  1. 1. # 指定以centos為基礎鏡像進行build   
  2. 2. FROM centos   

 

2)WORKDIR

WORKDIR用于指定工作目錄,所有執行的shell語句都會在該指定的目錄中運行,我們后面講的 RUN,CMD,COPY,ADD 等指令將會在指定的工作目錄中去執行。該指令也可以在一個Dockerfile文件中出現多次,最后一次出現的目錄依次是上個目錄的子目錄。如下所示:

 

  1. 1. WORKDIR /a   
  2. 2. WORKDIR b   
  3. 3. WORKDIR c   
  4. 4. RUN pwd   

 

最后這個pwd的命令執行的目錄為/a/b/c。我們繼續基于上面的指令來指定WORKDIR目錄為'/'

 

IT工程師都需要掌握的容器技術之Dockerfile

 

3)RUN

RUN 指令用于執行命令,該指令有兩種形式:

a. RUN ,使用 shell 去執行指定的命令 command,一般默認的 shell 為 /bin/sh -c

b. RUN ["executable", "param1", "param2"],使用可執行的文件或程序后面并可以跟上相關參數

下面我們通過這兩種形式來創建執行命令

 

  1. 1. # 第一種RUN指令方式   
  2. 2. RUN yum update   
  3. 3.    
  4. 4. # 第二種RUN指令方式   
  5. 5. RUN ["/bin/bash""-c""echo hello"]  

4)CMD

CMD 的使用方式跟 RUN 類似,其跟RUN的區別是RUN是在構建鏡像是運行執行而CMD是容器運行后執行的指令。在一個 Dockerfile 文件中只能有一個 CMD 指令,如果有多個 CMD 指令,則只有最后一個會生效。CMD也有三種命令格式具體如下

 

  1. 1. # 第一種執行命令推薦用法   
  2. 2. CMD ["executable","param1","param2"]   
  3. 3.    
  4. 4. # 第二種該格式主要配合ENTRYPOINT使用,CMD 指令的值會作為 ENTRYPOINT 指令的參數   
  5. 5. CMD ["param1","param2"]   
  6. 6.    
  7. 7. # 第三種執行shell form,該方法與第一種的執行效果一致   
  8. 8. CMD command param1 param2    

 

我們通過第一種方式來創建來執行wc的幫助指定具體如下

 

  1. 1. CMD ["/usr/bin/wc","--help"]   

第二種方法需要在Dockerfile中使用ENTRYPOINT指令,ENTRYPOINT 指令會覆蓋 CMD 指令作為容器運行時的默認指令,并且不會在 docker run 時被覆蓋,如下示例

 

  1. 1. FROM centos   
  2. 2. ENTRYPOINT ["ls""-a"]   
  3. 3. CMD ["-l"]   

 

上述構建的鏡像,在我們使用 docker run 時等同于 docker run ls -a l 命令。CMD 指令的值會被當作 ENTRYPOINT 指令的參數附加到 ENTRYPOINT 指令的后面,并且如果 docker run 中指定了參數,會覆蓋 CMD 中給出的參數。

5)COPY&ADD

COPY 和 ADD 都用于將文件,目錄等復制到鏡像中。兩者的區別在于ADD可以使用遠程URL路徑作為復制源,如果只復制本地文件建議使用COPY,兩個指令的語法格式如下:

 

  1. 1. # ADD命令格式   
  2. 2. ADD [--chown=<user>:<group>] <src>... <dest>   
  3. 3. ADD [--chown=<user>:<group>] ["<src>",... "<dest>"]   
  4. 4.    
  5. 5. # COPY命令格式   
  6. 6. COPY [--chown=<user>:<group>] <src>... <dest>   
  7. 7. COPY [--chown=<user>:<group>] ["<src>",... "<dest>"]   

--chown用于指定文件目錄用戶與權限, 可以指定多個,但是其路徑不能超出上下文的路徑,即必須在跟 Dockerfile 同級或子目錄中。 不需要預先存在,不存在路徑時會自動創建,如果沒有使用絕對路徑,則 為WORKDIR指定目錄的相對路徑。

6)ENV

ENV用于定義Dockerfile的環境變量,變量設置的值將在構建階段中所有后續指令的環境中使用,并且在許多情況下也可以內聯替換。其命令格式如下:

  1. 1. ENV <key>=<value> ...   

使用示例如下

 

  1. 1. # $MYDIR將被替換成"/mydir"   
  2. 2. ENV MYDIR="/mydir"   
  3. 3. RUN mkdir $MYDIR   

 

7)VOLUME

VOLUME用于在Dockerfile文件中指定掛載目錄,在容器運行時,將自動創建相應的匿名卷,其命令格式如下

 

  1. 1. VOLUME ["/data"]   

該條命令會在容器運行時創建一個匿名卷,同時將容器中/data目錄掛載到該卷上。

8)EXPOSE

EXPOSE指令通知Docker容器在運行時監聽指定的網絡端口。您可以指定端口是偵聽TCP還是UDP,如果未指定協議,則默認值為TCP。EXPOSE指令實際上并未發布端口。它充當構建映像的人員和運行容器的人員之間的一種文檔類型,有關打算發布哪些端口的信息。如果要將容器端口暴露出來,需要在 dcoker run 命令中使用 -p。

EXPOSE指令格式與用法示例如下:

 

  1. 1. # EXPOSE命令格式   
  2. 2. EXPOSE <port> [<port>/<protocol>...]   
  3. 3.    
  4. 4. # 使容器同時監聽TCP與UDP的80端口   
  5. 5. EXPOSE 80/tcp   
  6. 6. EXPOSE 80/udp   

 

03 Dockerfile鏡像構建

我們現在通過Dockerfile來構建一個nginx服務器,Dockerfile具體配置如下:

 

  1. 1. # 指定基礎鏡像   
  2. 2. FROM centos   
  3. 3.    
  4. 4. # 設置環境目錄   
  5. 5. WORKDIR /   
  6. 6.    
  7. 7. # 安裝nginx   
  8. 8. RUN yum install nginx -y   
  9. 9.    
  10. 10. # 容器對外暴露80端口   
  11. 11. EXPOSE 80   
  12. 12.    
  13. 13. # 啟動nginx   
  14. 14. CMD ["/usr/sbin/nginx""-g""daemon off;"]   

 

接著通過該Dockerfile文件進行鏡像構建,具體如下

 

IT工程師都需要掌握的容器技術之Dockerfile

 

 

IT工程師都需要掌握的容器技術之Dockerfile

 

最后我們啟動容器,同時查看nginx服務是否能夠訪問,具體操作如下

 

IT工程師都需要掌握的容器技術之Dockerfile

 

 

IT工程師都需要掌握的容器技術之Dockerfile

 

 

IT工程師都需要掌握的容器技術之Dockerfile

 

責任編輯:華軒 來源: 今日頭條
相關推薦

2020-11-25 09:27:49

Docker容器技術

2020-10-19 09:32:49

容器Docker管理

2020-10-26 15:11:50

Docker容器IT

2020-10-27 10:52:37

Docker容器存儲

2020-03-17 15:15:49

Python工程師面試題

2010-08-10 13:22:41

2020-07-22 14:50:35

Python數據分析

2022-08-12 09:21:43

前端JavaScript代碼

2020-08-05 08:25:58

大數據Java技術

2021-03-31 22:25:46

運維工程師技能

2017-09-22 08:33:34

機器學習Web設計UI

2010-08-10 13:29:58

軟件工程師

2013-08-15 09:47:27

企業網絡簡化網絡工程師

2012-03-31 16:57:52

工程師創業團隊

2025-06-12 01:11:11

AsyncAwait函數

2018-12-29 15:10:22

工程師爬蟲Python

2021-03-24 15:15:34

數據工程師開發工具

2021-03-09 10:24:46

數學計算機系統架構師

2021-03-09 10:47:56

系統架構師算法工程師人工智能工程師

2012-02-13 17:13:00

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲免费一区二区 | 91免费视频 | 欧美日韩综合一区 | 成人免费片| 欧美综合一区二区三区 | 99精品视频一区二区三区 | 手机看片在线播放 | 色综合区 | 人人鲁人人莫人人爱精品 | 成人精品一区 | 999久久 | 国产一区二区三区久久久久久久久 | 久久久久久久久久久久久9999 | 国产视频观看 | 成人毛片视频免费 | 亚洲成人一区二区 | 精品欧美一区二区三区久久久 | 亚洲免费在线 | 精品一区二区三区免费视频 | 国产性色视频 | 国产极品粉嫩美女呻吟在线看人 | 日本不卡高字幕在线2019 | 九九视频在线观看 | 一区二区三区亚洲精品国 | 日韩视频精品在线 | 亚洲精品一区二区三区四区高清 | 日本久久久久久 | 久久久久国色av免费观看性色 | 日日干干夜夜 | 香蕉一区| 国产精品久久久久久av公交车 | 国产一区二区三区高清 | 激情五月综合网 | av片网| 激情六月天 | 91精品国产乱码久久久久久久久 | 亚洲精品区 | 一区二区福利视频 | 中文字幕精品一区 | 久草热在线 | 精品毛片在线观看 |