<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          Docker 鏡像優(yōu)化:從 1.16 GB 到 22.4MB!怎么做到的??

          共 3166字,需瀏覽 7分鐘

           ·

          2021-09-27 08:59

          點擊關(guān)注公眾號,Java干貨及時送達(dá)

          來源:http://blog.csdn.net/update7

          Docker簡介

          Docker 是一個供軟件開發(fā)人員和系統(tǒng)管理員使用容器構(gòu)建、運(yùn)行和與分享應(yīng)用程序的平臺。容器是在獨立環(huán)境中運(yùn)行的進(jìn)程,它運(yùn)行在自己的文件系統(tǒng)上,該文件系統(tǒng)是使用 docker 鏡像構(gòu)建的。鏡像中包含運(yùn)行應(yīng)用程序所需的一切(編譯后的代碼、依賴項、庫等等)。鏡像使用 Dockerfile 文件定義。

          術(shù)語 dockerization 或 containerization 通常用于定義創(chuàng)建 Docker 容器的過程。

          因為容器具備如下優(yōu)點,所以很受歡迎:

          在這篇文章中,我將重點討論如何優(yōu)化 Docker 鏡像以使其輕量化。另外,Dokcer 系列教程全部整理好了,微信搜索Java技術(shù)棧,可以在線閱讀。

          優(yōu)化過程

          讓我們從一個示例開始,在該示例中,我們構(gòu)建了一個 React 應(yīng)用程序并將其容器化。運(yùn)行 npx 命令并創(chuàng)建 Dockerfile 之后,我們得到了如圖 1 所示的文件結(jié)構(gòu)。

          npx create-react-app app --template typescript
          圖 1:文件結(jié)構(gòu)

          如果我們構(gòu)建一個基礎(chǔ)的 Dockerfile(如下所示),我們最終會得到一個 1.16 GB 的鏡像:

          FROM node:10 
          WORKDIR /app
          COPY app /app
          RUN npm install -g webserver.local
          RUN npm install && npm run build 
          EXPOSE 3000
          CMD webserver.local -d ./build
          圖 2:鏡像的初始大小為 1.16GB

          第一步優(yōu)化:使用輕量化基礎(chǔ)鏡像

          在 Docker Hub(公共 Docker 倉庫)中,有一些鏡像可供下載,每個鏡像都有不同的特征和大小。

          通常,相較于基于其他 Linux 發(fā)行版(例如 Ubuntu)的鏡像,基于 Alpine 或 BusyBox 的鏡像非常小。這是因為 Alpine 鏡像和類似的其他鏡像都經(jīng)過了優(yōu)化,其中僅包含最少的必須的軟件包。

          在下面的圖片中,你可以看到 Ubuntu、Alpine、Node 和基于 Alpine 的 Node 鏡像之間的大小比較。

          圖 3:基礎(chǔ)鏡像的不同大小

          通過修改 Dockerfile 并使用 Alpine 作為基礎(chǔ)鏡像,我們的鏡像最終大小為 330MB:

          FROM node:10-alpine 
          WORKDIR /app
          COPY app /app
          RUN npm install -g webserver.local
          RUN npm install && npm run build 
          EXPOSE 3000
          CMD webserver.local -d ./build
          圖 4:經(jīng)過第一步優(yōu)化后鏡像大小為 330MB

          第二步優(yōu)化:多階段構(gòu)建

          通過多階段構(gòu)建,我們可以在 Dockerfile 中使用多個基礎(chǔ)鏡像,并將編譯成品、配置文件等從一個階段復(fù)制到另一個階段,這樣我們就可以丟棄不需要的東西。

          在本例中,我們部署 React 應(yīng)用程序需要的是編譯后的代碼,我們不需要源文件,也不需要 node_modules 目錄和 package.json 文件等。推薦一個 Spring Boot 基礎(chǔ)教程及實戰(zhàn)示例:https://github.com/javastacks/spring-boot-best-practice

          通過將 Dockerfile 修改為如下內(nèi)容,我們最終得到的鏡像大小為 91.5MB。請記住,來自第一階段(第 1-4 行)的鏡像不會被自動刪除,Docker 將它保存在 cache 中,如果我們在另一個構(gòu)建鏡像過程中執(zhí)行了相同的階段,就可以使鏡像構(gòu)建更快。所以你必須手動刪除第一階段鏡像。

          FROM node:10-alpine AS build
          WORKDIR /app
          COPY app /app
          RUN npm install && npm run build  
          FROM node:10-alpineWORKDIR /app
          RUN npm install -g webserver.local
          COPY --from=build /app/build ./build
          EXPOSE 3000
          CMD webserver.local -d ./build
          圖 5:第二步優(yōu)化后的鏡像大小為 91.5MB

          現(xiàn)在我們有了一個 Dockerfile,它有兩個階段:在第一個階段中,我們編譯項目,在第二個階段中,我們在 web 服務(wù)器上部署應(yīng)用程序。然而,Node 容器并不是提供網(wǎng)頁(HTML、CSS 和 JavaScript 文件、圖片等)服務(wù)的最佳選擇,最好的選擇是使用像 Nginx 或 Apache 這樣的服務(wù)。

          在本例中,我將使用 Nginx。另外,Nginx 系列面試題和答案全部整理好了,微信搜索Java技術(shù)棧,在后臺發(fā)送:面試,可以在線閱讀。

          通過將 Dockerfile 修改為如下內(nèi)容,我們的鏡像最終大小是 22.4MB,如果我們運(yùn)行這個容器,我們可以看到網(wǎng)頁可以正常工作,沒有任何問題(圖 7)。

          FROM node:10-alpine AS build
          WORKDIR /app
          COPY app /app
          RUN npm install && npm run build  
          FROM nginx:stable-alpine
          COPY --from=build /app/build /usr/share/nginx/html
          EXPOSE 80
          CMD ["nginx""-g""daemon off;"]
          圖 6:第三步優(yōu)化后的鏡像大小為 22.4MB
          圖 7:最終容器的運(yùn)行結(jié)果






          關(guān)注Java技術(shù)棧看更多干貨



          獲取 Spring Boot 實戰(zhàn)筆記!

          瀏覽 41
          點贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  大香蕉伊看人在线在线观看 | 91麻豆精品无码一区二区三区 | 亚洲无码五月丁香 | 自拍影音先锋 | 青青草在线视频黄色 |