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

Spring Boot2.3 新特性分層JAR的使用

 更新時間:2020年06月11日 10:19:32   作者:冷冷zz  
這篇文章主要介紹了Spring Boot2.3 新特性分層JAR的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

背景

在我們實際生產(chǎn)容器化部署過程中,往往會遇到 Docker 鏡像很大,部署發(fā)布很慢的情況

影響 docker 鏡像大小的因素,主要有以下三個方面:

  1. 基礎(chǔ)鏡像的大小 。盡量選擇 alpine 作為基礎(chǔ)鏡像 減少操作系統(tǒng)內(nèi)置軟件
  2. Dockerfile 指令層數(shù)。 這就要求我們優(yōu)化 Dockerfile 能合并在一行的盡量合并等
  3. 應用 jar 的大小。這是今天要分享的重點內(nèi)容

helloworld 鏡像

我們先來基于 spring boot 2.3.0 構(gòu)建一個最簡單的 web helloworld,然后構(gòu)建鏡像。

FROM adoptopenjdk:11-jre-hotspot as builder
WORKDIR application
ARG JAR_FILE=target/*.jar
COPY ${JAR_FILE} application.jar
ENTRYPOINT ["java", "-jar application.jar"]
docker build --build-arg JAR_FILE=./demo-layer-0.0.1-SNAPSHOT.jar . -t demo:v1.0

查看鏡像分層信息

我們通過 docker inspect demo:v1.0 來看下此鏡像的每層的散列值

// demo:v1.0 版本鏡像分層信息摘要
"Layers": [
  "sha256:b7f7d2967507ba709dbd1dd0426a5b0cdbe1ff936c131f8958c8d0f910eea19e",
  "sha256:a6ebef4a95c345c844c2bf43ffda8e36dd6e053887dd6e283ad616dcc2376be6",
  "sha256:838a37a24627f72df512926fc846dd97c93781cf145690516e23335cc0c27794",
  "sha256:28ba7458d04b8551ff45d2e17dc2abb768bf6ed1a46bb262f26a24d21d8d7233",
  "sha256:55c91231ac46fdd63c3cf84b88b11f8a04c1870482dcff033029a601bc50e1ab",
  "sha256:9816c2d488754509f6024a267738b1e5fe33a7cd33bd25c5a9cdf6d4d7bfed1d",
  "sha256:f5fb3f91797d57a92f3f7e033398b8edd094df664db849a4950eabf2f5474535",
  "sha256:b87d2ff74819f83038ea2f89736a19cfcf99bfa080b8017d191c900a09a7524f"
]

helloworld 升級重新構(gòu)建

我們對 helloworld 程序進行部分修改(模擬開發(fā)過程),然后重新構(gòu)建鏡像

docker build --build-arg JAR_FILE=./demo-layer-0.0.1-SNAPSHOT.jar . -t demo:v1.1

此時鏡像分層信息如下 docker inspect demo:v1.1

// demo:v1.1 版本鏡像分層信息摘要
"Layers": [
  "sha256:b7f7d2967507ba709dbd1dd0426a5b0cdbe1ff936c131f8958c8d0f910eea19e",
  "sha256:a6ebef4a95c345c844c2bf43ffda8e36dd6e053887dd6e283ad616dcc2376be6",
  "sha256:838a37a24627f72df512926fc846dd97c93781cf145690516e23335cc0c27794",
  "sha256:28ba7458d04b8551ff45d2e17dc2abb768bf6ed1a46bb262f26a24d21d8d7233",
  "sha256:55c91231ac46fdd63c3cf84b88b11f8a04c1870482dcff033029a601bc50e1ab",
  "sha256:9816c2d488754509f6024a267738b1e5fe33a7cd33bd25c5a9cdf6d4d7bfed1d",
  "sha256:f5fb3f91797d57a92f3f7e033398b8edd094df664db849a4950eabf2f5474535",
  "sha256:c1b6350d545fea605e0605c4bfd7f4529cfeee3f6759750d6a5ddeb9c882fc8f"
]

比較 v1.0、v1.1 鏡像

通過比較 v1.0 和 v1.1 版本的鏡像摘要信息,我們會發(fā)現(xiàn)只有最后的一層發(fā)生了變化,我們通過 Dive 是一個用 Go 語言編寫的 Docker 鏡像分析工具 來確定一下 最后一層是做了哪些事情
dive demo:v1.0,「大家會看到是最后的 jar 不一樣 導致 16M 的內(nèi)容需要重新構(gòu)建,當你的業(yè)務 jar 很大時,這塊就是性能瓶頸」

spring boot 默認打包解密

默認情況下,spring boot 構(gòu)建出來的 jar ,解壓后可以看到如下目錄結(jié)構(gòu)。默認會當做一個整體 ,在構(gòu)建鏡像時作為一個單獨層,「沒有區(qū)分業(yè)務 classes 和 引用的第三方 jar」

META-INF/
 MANIFEST.MF
org/
 springframework/
  boot/
   loader/
BOOT-INF/
 classes/
 lib/

layer jar

通過上文大家就可以知道分層 jar 的思想就是把,jar 再根據(jù)規(guī)則細分,業(yè)務 class 和 三方 jar 分別對應鏡像的不同層,這樣改動業(yè)務代碼,只需變動很少的內(nèi)容 提高構(gòu)建速度。

開啟分層打包

 <plugin>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-maven-plugin</artifactId>
  <configuration>
   <layers>
    <enabled>true</enabled>
   </layers>
  </configuration>
 </plugin>

編寫支持分層 Dockerfile

核心是通過 spring boot 提供的 layertools 工具,將 jar 進行拆分 然后通過 COPY 指令去分別加載

FROM adoptopenjdk:11-jre-hotspot as builder
WORKDIR application
ARG JAR_FILE=target/*.jar
COPY ${JAR_FILE} application.jar
RUN java -Djarmode=layertools -jar application.jar extract
FROM adoptopenjdk:11-jre-hotspot
WORKDIR application
COPY --from=builder application/dependencies/ ./
COPY --from=builder application/spring-boot-loader/ ./
COPY --from=builder application/snapshot-dependencies/ ./
COPY --from=builder application/application/ ./
ENTRYPOINT ["java", "org.springframework.boot.loader.JarLauncher"]

構(gòu)建新鏡像并查看分層信息

docker build --build-arg JAR_FILE=./demo-layer-0.0.1-SNAPSHOT.jar . -t demo:v2.0

"Layers": [
  "sha256:b7f7d2967507ba709dbd1dd0426a5b0cdbe1ff936c131f8958c8d0f910eea19e",
  "sha256:a6ebef4a95c345c844c2bf43ffda8e36dd6e053887dd6e283ad616dcc2376be6",
  "sha256:838a37a24627f72df512926fc846dd97c93781cf145690516e23335cc0c27794",
  "sha256:28ba7458d04b8551ff45d2e17dc2abb768bf6ed1a46bb262f26a24d21d8d7233",
  "sha256:55c91231ac46fdd63c3cf84b88b11f8a04c1870482dcff033029a601bc50e1ab",
  "sha256:9816c2d488754509f6024a267738b1e5fe33a7cd33bd25c5a9cdf6d4d7bfed1d",
  "sha256:f5fb3f91797d57a92f3f7e033398b8edd094df664db849a4950eabf2f5474535",
  "sha256:06fe18cf8ae7384f120f2c6a3a33b31999dd0460cf1edae45e8f13adeab35942",
  "sha256:16cf814564b8a667fcc9f07314b6084cbef8dc8c0a6565c7a2d91d74faf7e7de",
  "sha256:94be40f716016b68cdd6b99d2cb8154acf8475c3a170a898a22f95a8ef40ffd3",
  "sha256:427d87d6a5fe6da13cb4233939c3a1ff920bc6b4d2f14b5d78af7aef98fda7de"
]

修改代碼部分業(yè)務代碼,重新構(gòu)建

docker build --build-arg JAR_FILE=./demo-layer-0.0.1-SNAPSHOT.jar . -t demo:v2.1
"Layers": [
  "sha256:b7f7d2967507ba709dbd1dd0426a5b0cdbe1ff936c131f8958c8d0f910eea19e",
  "sha256:a6ebef4a95c345c844c2bf43ffda8e36dd6e053887dd6e283ad616dcc2376be6",
  "sha256:838a37a24627f72df512926fc846dd97c93781cf145690516e23335cc0c27794",
  "sha256:28ba7458d04b8551ff45d2e17dc2abb768bf6ed1a46bb262f26a24d21d8d7233",
  "sha256:55c91231ac46fdd63c3cf84b88b11f8a04c1870482dcff033029a601bc50e1ab",
  "sha256:9816c2d488754509f6024a267738b1e5fe33a7cd33bd25c5a9cdf6d4d7bfed1d",
  "sha256:f5fb3f91797d57a92f3f7e033398b8edd094df664db849a4950eabf2f5474535",
  "sha256:06fe18cf8ae7384f120f2c6a3a33b31999dd0460cf1edae45e8f13adeab35942",
  "sha256:16cf814564b8a667fcc9f07314b6084cbef8dc8c0a6565c7a2d91d74faf7e7de",
  "sha256:94be40f716016b68cdd6b99d2cb8154acf8475c3a170a898a22f95a8ef40ffd3",
  "sha256:8a20c60d361696a4e480fb6fbe1daf8b88bc54c579a98e209da1fb76e25de5aa"
]

查看區(qū)別層鏡像

最后一層變動大小為 5KB

總結(jié)

16MB -> 5KB 變動,在實際開發(fā)過程中 效果會更加明顯可以通過 spring boot maven plugin 指定分層邏輯,具體可以參考官方文檔官方文檔: https://docs.spring.io/spring-boot/docs/2.3.0.RELEASE/maven-plugin/reference/html/

到此這篇關(guān)于Spring Boot2.3 新特性分層JAR的使用的文章就介紹到這了,更多相關(guān)Spring Boot2.3 分層JAR內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

作者:冷冷zz
鏈接:https://lltx.github.io

相關(guān)文章

  • JFreeChart插件實現(xiàn)的折線圖效果實例

    JFreeChart插件實現(xiàn)的折線圖效果實例

    這篇文章主要介紹了JFreeChart插件實現(xiàn)的折線圖效果,結(jié)合實例形式分析了基于JFreeChart繪制折線圖的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2016-08-08
  • 一篇文章幫你搞懂什么是java的進程和線程

    一篇文章幫你搞懂什么是java的進程和線程

    這篇文章主要介紹了java 線程詳解及線程與進程的區(qū)別的相關(guān)資料,網(wǎng)上關(guān)于java 線程的資料很多,對于進程的資料很是,這里就整理下,需要的朋友可以參考下
    2021-08-08
  • Java輸入數(shù)據(jù)的知識點整理

    Java輸入數(shù)據(jù)的知識點整理

    在本篇文章里小編給大家整理的是關(guān)于Java如何輸入數(shù)據(jù)的相關(guān)知識點內(nèi)容,有興趣的朋友們學習參考下。
    2020-01-01
  • SpringMVC框架的介紹與使用詳解

    SpringMVC框架的介紹與使用詳解

    SpringMVC?是一種基于?Java?的實現(xiàn)?MVC?設(shè)計模型的請求驅(qū)動類型的輕量級?Web?框架,跟Spring,Mybatis框架并稱為ssm,這篇文章主要介紹了SpringMVC框架的介紹與使用,需要的朋友可以參考下
    2022-08-08
  • 基于SpringBoot實現(xiàn)大文件分塊上傳功能

    基于SpringBoot實現(xiàn)大文件分塊上傳功能

    這篇文章主要介紹了基于SpringBoot實現(xiàn)大文件分塊上傳功能,實現(xiàn)原理其實很簡單,核心就是客戶端把大文件按照一定規(guī)則進行拆分,比如20MB為一個小塊,分解成一個一個的文件塊,然后把這些文件塊單獨上傳到服務端,需要的朋友可以參考下
    2024-09-09
  • java基于mongodb實現(xiàn)分布式鎖的示例代碼

    java基于mongodb實現(xiàn)分布式鎖的示例代碼

    本文主要介紹了java基于mongodb實現(xiàn)分布式鎖,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • java中PriorityBlockingQueue的入隊知識點總結(jié)

    java中PriorityBlockingQueue的入隊知識點總結(jié)

    在本篇文章里小編給大家整理一篇關(guān)于java中PriorityBlockingQueue的入隊知識點總結(jié)內(nèi)容,有需要的朋友們可以學習下。
    2021-01-01
  • SpringBoot整合MongoDB實現(xiàn)事務管理

    SpringBoot整合MongoDB實現(xiàn)事務管理

    Spring Boot是一種快速開發(fā)Spring應用的方式,它提供了大量的自動配置和默認設(shè)置,以簡化開發(fā)流程,MongoDB是一個基于文檔的NoSQL數(shù)據(jù)庫,本文將介紹如何在Spring Boot應用中整合MongoDB,并實現(xiàn)事務管理,需要的朋友可以參考下
    2024-07-07
  • java 實現(xiàn)讀取clob

    java 實現(xiàn)讀取clob

    這篇文章主要介紹了java 如何實現(xiàn)讀取clob,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2020-10-10
  • Java JDBC導致的反序列化攻擊原理解析

    Java JDBC導致的反序列化攻擊原理解析

    這篇文章主要介紹了Java JDBC導致的反序列化攻擊原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12

最新評論