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

Docker優秀實踐:5個方法精簡你的鏡像

新聞 前端
基于Dockerfile生成鏡像,使用這個鏡像生成的容器,我們要盡可能的縮短容器的生命周期。這里我的理解是,不要將容器當做vm 來使用, 這個容器可以被停止或者銷毀, 然后可以根據設置和配置的變動重新生成新的容器。

 [[323396]]

創建短生命周期容器

基于Dockerfile生成鏡像,使用這個鏡像生成的容器,我們要盡可能的縮短容器的生命周期。這里我的理解是,不要將容器當做vm 來使用, 這個容器可以被停止或者銷毀, 然后可以根據設置和配置的變動重新生成新的容器。

理解構建上下文

當你觸發docker build 命令時,當前目錄就被稱為構建上下文(build context)。默認情況下 Dockerfile文件就在這個目錄下, 但是可以通過 -f 參數來指定Dockerfile的位置。不管Dockerfile在哪里,當前目錄中的所有文件和目錄都會作為構建上下文發送到 docker daemon 進程。

構建上下文示例

創建一個目錄并且使用cd進入該目錄。在hello文件中寫”hello”,同時創建 Dockerfile文件并且cat hello文件。在當前上下文(.)中構建鏡像:

  1. mkdir myproject && cd myproject 
  2.  
  3. echo "hello" > hello 
  4.  
  5. echo -e "FROM busyboxnCOPY /hello /nRUN cat /hello" > Dockerfile 
  6.  
  7. docker build -t helloapp:v1 . 

將Dockerfile 和 hello 文件移動到另一個目錄中。并且再構建一個鏡像(不使用上個鏡像構建緩存)。使用-f來指定 Dockerfile 并且明確上下文目錄:

  1. mkdir -p dockerfiles context 
  2.  
  3. mv Dockerfile dockerfiles && mv hello context 
  4.  
  5. docker build --no-cache -t helloapp:v2 -f dockerfiles/Dockerfile context 

在構建過程中導入了不必要的文件將會導致更大的構建上下文,從而會構建出更大的鏡像。這會增加構建鏡像的時間,拉取和上傳鏡像的時間以及容器的大小。當你使用Dockerfile構建鏡像時,可通過如下信息查看你的構建上下文的大小:

Sending build context to Docker daemon 187.8MB

使用.dockerignore 排除不需要加入鏡像的文件

有的時候我們會需要排除一些與我們構建鏡像不相關的文件,這時候我們可以通過編寫.dockerignore在不改變代碼結構的情況下達到這一目的。這個文件的實現方式與.gitignore很像,關于如何創建一個.dockerignore,可以參考.dockerignore file

使用多階段構建

multi-stage builds 技術可以大幅度減少最終鏡像的大小,而不是想辦法去減少構建過程中的層級數和文件。

因為鏡像是在構建過程最后階段生成的,因此我們可以通過leveraging build cache來最小化鏡像層。

舉個例子來說,如果構建一個鏡像,這個鏡像有很多層,可以按照鏡像層的修改頻率來排序(就是將不經常更新的層作為最底層,這樣可以復用構建緩存):

  • 安裝工具
  • 安裝或者更新依賴
  • 生成你的應用

一個 Go 應用的 Dockerfile示例:

  1. FROM golang:1.11-alpine AS build 
  2.  
  3. # Install tools required for project 
  4.  
  5. # Run `docker build --no-cache .` to update dependencies 
  6.  
  7. RUN apk add --no-cache git 
  8.  
  9. RUN go get github.com/golang/dep/cmd/dep 
  10.  
  11. # List project dependencies with Gopkg.toml and Gopkg.lock 
  12.  
  13. # These layers are only re-built when Gopkg files are updated 
  14.  
  15. COPY Gopkg.lock Gopkg.toml /go/src/project/ 
  16.  
  17. WORKDIR /go/src/project/ 
  18.  
  19. # Install library dependencies 
  20.  
  21. RUN dep ensure -vendor-only 
  22.  
  23. # Copy the entire project and build it 
  24.  
  25. # This layer is rebuilt when a file changes in the project directory 
  26.  
  27. COPY . /go/src/project/ 
  28.  
  29. RUN go build -o /bin/project 
  30.  
  31. # This results in a single layer image 
  32.  
  33. FROM scratch 
  34.  
  35. COPY --from=build /bin/project /bin/project 
  36.  
  37. ENTRYPOINT ["/bin/project"
  38.  
  39. CMD ["--help"

不安裝不需要的包

為了減小鏡像的復雜度和大小, 我們應當避免安裝一些我們不需要的 packages。舉個例子來說,你不需要在數據庫鏡像中安裝文本編輯器。

應用解耦

每個容器應當只含有一個應用實例, 將多個應用解耦至多個容器可以很方便的對應用進行水平擴展,并且可以復用容器。舉個例子來說,一個 web 應用應當包含三個容器(web容器, 數據庫容器, 緩存容器),每一個容器對應一個鏡像。

每個容器中限制只能有一個進程是一個很好的經驗法則, 但這也不是一個硬性的規定。容器中的進程不僅可以由 init 創建, 一些程序可能會額外的生成一些他們自己的進程。比如, Celery會生成多個 worker 進程, Apache 對每一個請求創建一個進程。

每種場景不一樣,規則也不一樣。但是應該盡可能的保證我們的容器功能明確和模塊化。如果容器之間相互依賴(容器之間可能需要通信), 你可以使用Docker container networks 確保容器間通信。

減小鏡像層數

減少鏡像層數對于鏡像構建非常重要。在更老的版本的 docker 中需要特別注意,現在通過下面的這些特性我們可以方便的對鏡像層數進行限制:

  • 只有 ONLY, COPY,ADD這三個命令增加層數,其他的命令只會創建一些臨時的鏡像,并不會增加構建的鏡像的層數
  • 使用 multi-stage builds只拷貝真正需要的artifaces(制品) 到最終的鏡像。這可以使你在構建過程中使用工具和打印調試信息,但不會增加最終的鏡像大小。

對多行參數排序

只要有可能, 將參數按照字母進行排序是一種非常好的實踐,這種方式可以避免重復安裝包(特指apt-get命令),也可以是開發人員更加容易的閱讀和審查。

下面是 buildpack-deps鏡像的例子 images:

  1. RUN apt-get update && apt-get install -y 
  2.  
  3. bzr 
  4.  
  5. cvs 
  6.  
  7. git 
  8.  
  9. mercurial 
  10.  
  11. subversion 

借助構建緩存

在構建鏡像的時候,docker 會按照dockerfile中的指令順序來一次執行。每一個指令被執行的時候 docker 都會去緩存中檢查是否有已經存在的鏡像可以復用,而不是去創建一個新的鏡像復制。

如果不想使用構建緩存,可以使用docker build參數選項—no-cache=true來禁用構建緩存。在使用鏡像緩存時,要弄清楚緩存合適生效,何時失效。構建緩存最基本規則如下:

  • 如果引用的父鏡像在構建緩存中,下一個命令將會和所有從該父進程派生的子鏡像做比較,如果有子鏡像使用相同的命令,那么緩存命中,否則緩存失效。
  • 在大部分情況下,通過比較Dockerfile中的指令和子鏡像已經足夠了。但是有些指令需要進一步的檢查。
  • 對于ADD和COPY指令, 文件的內容會被檢查,并且會計算每一個文件的校驗碼。但是文件最近一次的修改和訪問時間不在校驗碼的考慮范圍內。在構建過程中,docker 會比對已經存在的鏡像,只要有文件內容和元數據發生變動,那么緩存就會失效。
  • 除了ADD和COPY指令,鏡像緩存不會檢查容器中文件來判斷是否命中緩存。例如,在處理RUN apt-get -y update命令時,不會檢查容器中的更新文件以確定是否命中緩存,這種情況下只會檢查命令字符串是否相同。 

 

責任編輯:張燕妮 來源: 高效運維
相關推薦

2021-03-01 19:24:13

Kubernetes備份容器

2021-05-08 16:11:08

Java開發代碼

2023-01-13 16:34:08

2023-04-10 11:25:29

工程交流DX

2020-09-29 07:19:54

InnoDBMySQL存儲引擎

2019-12-16 12:11:53

Docker容器Kubernetes

2020-02-03 12:25:35

Python工具服務器

2021-05-10 16:41:19

機器學習人工智能IT

2023-09-20 09:00:00

2021-02-21 09:33:19

Docker容器安全 應用程序

2023-03-15 15:54:36

Java代碼

2022-04-19 10:17:20

云遷移云原生可觀測

2021-06-25 14:50:21

DevSecOps安全 DevOps

2020-10-27 06:56:53

IoT產品實踐

2022-02-28 15:56:14

零信任企業

2020-11-24 10:32:16

CIO首席信息官工具

2022-10-10 14:53:00

云安全云計算云平臺

2020-12-14 09:00:00

云計算公有云工具

2022-05-13 08:17:05

HTTPRESTful架構

2017-06-06 11:59:26

Docker工具容器
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日本免费视频 | 亚洲国产一区二区三区 | 国产高清一二三区 | 色性av| 国产在线观看一区二区三区 | 麻豆精品久久 | 天天操夜夜操 | 色天堂影院| 免费看91| 婷婷丁香在线视频 | 欧美色欧美亚洲另类七区 | 国产精品96久久久久久 | av黄色在线观看 | 久久av网 | 日韩欧美一区二区三区免费看 | 久久视频免费观看 | 久久国产精品首页 | 欧美在线一区二区三区 | 日韩成人一区 | 伊人伊人 | 岛国av一区二区 | 亚洲免费毛片 | 久久成人精品 | 国产精品久久欧美久久一区 | 99视频在线| 天天久久 | 91视频精选 | 一级片视频免费 | 欧美精 | 国产一区欧美 | 国产视频精品区 | 久国久产久精永久网页 | 国产一区二区在线免费 | 伊人影院在线观看 | 日本三级在线视频 | 91社区在线观看高清 | 亚洲在线视频 | 成人h片在线观看 | 91久久国产综合久久 | 亚洲视频1区 | 亚洲精品久久久久中文字幕二区 |