優化Docker鏡像,加速應用部署,教你6個小竅門


爲了讓用戶的雲端應用管理更高效、更方便,今天從6個方面分享一些溜到飛起的Docker鏡像優化小竅門。

往期回顧:你想知道的React組件設計模式這裏都有(下)php


明確指定鏡像版本,管理更方便

爲了讓版本管理起來更方便,應用部署速度更快,在建立鏡像的過程當中,建議工程師們明確指定包含版本或者其餘輔助信息的tag。node

若是不指定鏡像tag,默認會使用latest。每次啓動應用實例時,都須要去鏡像倉庫檢查鏡像是否更新。這種方式不利於版本管理,對應用啓動速度也有必定影響。python

2種方法減少鏡像體積

一、使用alpine版本的基礎鏡像,來減少鏡像體積,以保證部署和擴容速度。nginx

alpine是一個高度精簡又包含了基本工具的輕量級Linux發行版,自己的Docker鏡像只有4~5M大小。各開發語言和框架都有基於alpine製做的基礎鏡像,在開發本身應用的鏡像時,選擇這些鏡像做爲基礎鏡像,能夠大大減少鏡像的體積。 spring

各類語言對應的基礎鏡像以下:docker

  • Java(Spring Boot): - openjdk:8-jdk-alpine,openjdk:8-jre-alpine等npm

  • Java(Tomcat) - tomcat:8.5-alpine等後端

  • Nodejs - node:9-alpine, node:8-alpine等設計模式

  • Python - python:3-alpine, python:2-alpine等緩存

  • PHP - 基於php:7-fpm-alpine,php:5-fpm-alpine等鏡像添加nginx,參考https://hub.docker.com/r/trafex/alpine-nginx-php7/

  • Ruby:ruby:2-alpine等

  • Go/可執行文件 - 直接基於alpine鏡像,把編譯後的可執行文件打入鏡像。由於alpine不一樣於普通的Ubuntu/Centos等發行版,須要靜態編譯和連接應用代碼,例如Go須要關閉cgo:CGO_ENABLED=0 go build ...

  • 靜態頁面 - nginx:1-alpine等

二、保證Dockerfile中的清理命令在同一行,也能夠減少鏡像體積。

(上面的語句形式能夠減少鏡像體積。)

Dockerfile的每條指令都會產生一個文件層,組件的安裝清理要放在一條命令裏面。
利用分層機制,減少鏡像傳輸大小
利用分層機制,能夠減少鏡像傳輸大小,加快鏡像的推送和拉取速度
Docker在build鏡像的時候,若是某個命令相關的內容沒有變化,會使用上一次緩存(cache)的文件層,在上傳到鏡像倉庫時,這一層也就不須要上傳了。
利用這一點,在添加應用的時候能夠分層添加,具體操做以下:
(1)將不變或者變化不多的體積較大的依賴庫和常常修改的自有代碼分開
(2)由於cache緩存在運行Dockerbuild命令的本地機器上,建議固定使用某臺機器來進行Docker build,以便利用cache(更多相關信息,能夠參考 https://runnable.com/blog/distributing-docker-cache-across-hosts )
舉個例子:
在構建Spring Boot應用鏡像,咱們能夠經過如下操做來進行分層。
Step1:在Dockerfile所在目錄,解壓縮maven生成的jar包
unzip <path-to-app-jar>.jar -d app複製代碼
Step2: Dockerfile 咱們把應用的內容分紅4個部分COPY到鏡像裏面:其中前面3個基本不變,第4個是常常變化的自有代碼。最後一行是解壓縮後,啓動spring boot應用的方式。
其餘類型的應用,好比Java WAR包,Nodejs的npm模塊等,能夠採起相似的方式。
避免使用進程管理程序,保證應用健康運行

在應用的某個實例崩潰或者非正常退出時,不少進程管理程序並不退出,致使平臺沒法檢測到應用已經不可用,進而沒法重啓應用。因此要避免使用這類進程管理程序來啓動鏡像。

2種方法幫助Java應用運行調優
用如下兩種方式可讓Java應用感知到容器的內存限制,避免內存溢出。
一、使用新版本JavaSE 8 ( ≥ 8u131),啓動命令加上以下參數,自適應容器內存限制(MaxRAMFraction這個參數須要根據實際狀況調整,1並非普適值)
二、直接指定heap相關的參數。這種方式缺少靈活性,在確切知道內存限制大小的狀況下可使用。
2點要求保證數據和日誌持久化存儲

一、避免使用本地存儲。應用鏡像啓動後,文件系統是臨時的,崩潰後即被銷燬。持久化數據,文件等須要存儲到SDS,FDS等後端存儲服務中

二、應用日誌不能寫到本地文件,須要寫到標準輸出或者標準錯誤,平臺負責收集、彙總和後續的各類處理。

但願以上幾點建議可以幫助你們避免或解決實際使用中的問題。

轉載請標明出處「小米雲技術」
相關文章
相關標籤/搜索