欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Docker?鏡像分層及dockerfile?編寫技巧

 更新時間:2022年01月17日 11:59:01   作者:一只小毛驢?呀  
Docker鏡像是由特殊的文件系統(tǒng)疊加而成,鏡像層是不可變的,如果在某一層中添加一個文件,然后在下一層中刪除它,則鏡像中依然會包含該文件,這篇文章主要介紹了Docker?鏡像分層及dockerfile?編寫,需要的朋友可以參考下

docker鏡像分層

分層介紹

Dockerfile中的每個指令都會創(chuàng)建一個新的鏡像層

鏡像層將被緩存和復(fù)用

當Dockerfile的指令修改了,復(fù)制的文件變化了,或者構(gòu)建鏡像時指定的變量不同了,對應(yīng)的鏡像層緩存就會失效

某一層的鏡像緩存失效之后,它之后的鏡像層緩存都會失效

鏡像層是不可變的,如果在某一層中添加一個文件,然后在下一層中刪除它,則鏡像中依然會包含該文件

Docker鏡像原理

  • Docker鏡像是由特殊的文件系統(tǒng)疊加而成
  • ·最底端是bootfs,并使用宿主機的bootfs
  • ·第二層是root文件系統(tǒng)rootfs,稱為base image
  • ·然后再往上可以疊加其他的鏡像文件
  • ·統(tǒng)一文件系統(tǒng)(Union File System)技術(shù)能夠?qū)⒉煌膶诱铣梢粋€文件系統(tǒng),為這些層提供了 一個統(tǒng)一的視角,這樣就隱藏了多層的存在,在用戶的角度看來,只存在一個文件系統(tǒng)。
  • ·一個鏡像可以放在另一個鏡像的上面。位于下面的鏡像稱為父鏡像,最底部的鏡像成為基礎(chǔ)鏡像。
  • ·當從一個鏡像啟動容器時,Docker會在最頂層加載一個讀寫文件系統(tǒng)作為容器。

1.base image:基礎(chǔ)鏡像
2.image:固化了一個標準運行環(huán)境,鏡像本身的功能-封裝一組功能性的文件,通過統(tǒng)一的方式,文件格式提供出來(只讀)
3.container:容器層(讀寫)
4.docker-server 端
5.呈現(xiàn)給docker-client (視圖)

鏡像分層模型 

 dockerfile 編寫

dockerfile操作指令

序號指令含義
1FROM 鏡像指定新鏡像所基于的鏡像,第 條指必須為from指令,每創(chuàng)建一個鏡像就需要一條from指令
2MAINTAINER 名字說明新鏡像的維護人信息
3RUN 命令在所基于的鏡像上執(zhí)行命令,并提交到新的鏡像中;docker內(nèi)每執(zhí)行一條命令都是run開頭
4CMD["要運行的程序","參數(shù)1","參數(shù)2"]指令啟動容器時要運行的命令或者腳本,Dockerfile只能有一條CMD命令, 如果指定多條則只能最后一條被執(zhí)行
5EXPOSE 端口號指定新鏡像加載到Docker時要開啟的端口
6ENV 環(huán)境變量 變量值設(shè)置一個環(huán)境變量的值,會被后面的run使用
7ADD 源文件、目錄 目標文件/目錄具體識別壓縮格式并且自動解壓,將源文件復(fù)制到目標文件,源文件要與dockerfile位于相同目錄中,或者一個URL
8COPY 源文件/目錄 目標文件/目錄將本地主機上的文件/目錄復(fù)制到目標地點,源文件/目錄要與Dockerfile在相同的目錄中
9VOLUME ["目錄"]在容器中創(chuàng)建一個掛載點
10USER 用戶名/UID指定運行容器時的用戶
11WORKDIR 路徑為后續(xù)的RUN、CMD、ENTRYPOINT指定工作目錄
12ONBUILD 命令指定所生成的鏡像作為一個基礎(chǔ)鏡像時所要運行的命令
13HEALTHCHECK健康檢查

ADD和copy區(qū)別

              ①Dockerfile中的COPY指令和ADD指令都可以將主機上的資源復(fù)制或加入到容器鏡像中,都是在構(gòu)建鏡像的過程中完成的
              ②copy只能用于復(fù)制(節(jié)省資源)
              ③ADD復(fù)制的同時,如果復(fù)制的對象時壓縮包,ADD還可以解壓(消耗資源)
              ④COPY指令和ADD指令的唯一區(qū)別在于是否支持從遠程URL獲取資源。COPY指令只能從執(zhí)行docker build所在的主機上讀取資源并復(fù)制到鏡像中。而ADD指令還支持通過URL從遠程服務(wù)器讀取資源并復(fù)制到鏡像中
              ⑤滿足同等功能的情況下,推薦使用COPY指令。ADD指令更擅長讀取本地tar文件并解壓縮

CMD和entrypoint區(qū)別

   一般還是會用entrypoint的中括號形式作為docker 容器啟動以后的默認執(zhí)行命令,里面放的是不變的部分,可變部分比如命令參數(shù)可以使用cmd的形式提供默認版本,也就是run里面沒有任何參數(shù)時使用的默認參數(shù)。如果我們想用默認參數(shù),就直接run,否則想用其他參數(shù),就run 里面加參數(shù)。

嘗試編寫dockerfile文件 部署nginx


mkdir nginx
cd nginx/
vim Dockerfile 
 
FROM centos:7      #基于基礎(chǔ)鏡像
MAINTAINER nginx   #用戶信息
RUN yum -y update   #安裝依賴關(guān)系
RUN yum install -y pcre-devel zlib-devel gcc gcc-c++ make
RUN useradd -M -s /sbin/nologin nginx                     #創(chuàng)建用戶
ADD nginx-1.12.0.tar.gz /usr/local/src                    #將源文件復(fù)制到目標文件,源文件要與 
                                                            Dockerfile位于相同目錄中,或者是 
                                                             一個URL
 
VOLUME ["/usr/local/nginx/html"]                        #在容器中創(chuàng)建一個掛載點
WORKDIR /usr/local/src                                  #指定工作目錄
WORKDIR nginx-1.12.0
RUN ./configure \
--prefix=/usr/local/nginx \--user=nginx \--group=nginx \--with-http_stub_status_module && make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
EXPOSE 80                                                   #暴露端口
RUN echo "demon off;" >>/usr/local/nginx/conf/nginx.conf
CMD nginx

docker運行nginx為什么要使用 daemon off

docker運行nginx為什么要使用 daemon off

到此這篇關(guān)于Docker 鏡像分層及dockerfile 編寫的文章就介紹到這了,更多相關(guān)Docker 鏡像分層內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論