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

Spring Boot 2.4新特性減少95%內(nèi)存占用問題

 更新時(shí)間:2020年12月23日 16:08:05   作者:冷冷zz  
這篇文章主要介紹了Spring Boot 2.4新特性減少95%內(nèi)存占用問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

節(jié)省 95%的內(nèi)存占用,減少 80%的啟動(dòng)耗時(shí)。

GraalVM 是一種高性能的虛擬機(jī),它可以顯著的提高程序的性能和運(yùn)行效率,非常適合微服務(wù)。最近比較火的 Java 框架 Quarkus 默認(rèn)支持 GraalVM

下圖為 Quarkus 和傳統(tǒng)框架(SpringBoot) 等對比圖,更快的啟動(dòng)速度、更小的內(nèi)存消耗、更短的服務(wù)響應(yīng)。

Spring Boot 2.4 開始逐步提供對 GraalVM 的支持,旨在提升上文所述的 啟動(dòng)、內(nèi)存、響應(yīng)的使用體驗(yàn)。

安裝 GraalVM

目前官方社區(qū)版本最新為 20.3.0 ,是基于 OpenJDK 8u272 and 11.0.9 定制的,可以理解為 OpenJDK 的衍生版本

官方推薦的是 SDKMAN 用于快速安裝和切換不同版本 JDK 的工具 ,類似于 nodejs 的 nvm。

使用類似命令即可完成指定版本安裝和指定默認(rèn)版本

sdk install java 11.0.9.hs-adpt
sdk default java 11.0.9.hs-adpt

不過安裝過程中需要從國外下載相關(guān)資源 ,筆者在嘗試后使用體驗(yàn)并不是很好,所有建議大家下載指定版本 GraalVM 安裝即可(和 JDK 安裝方式一樣)。

安裝成功查看版本

⋊> ~ java -version              11:30:34
openjdk version "11.0.9" 2020-10-20
OpenJDK Runtime Environment GraalVM CE 20.3.0 (build 11.0.9+10-jvmci-20.3-b06)
OpenJDK 64-Bit Server VM GraalVM CE 20.3.0 (build 11.0.9+10-jvmci-20.3-b06, mixed mode, sharing)

安裝 native-image

native-image 是由 Oracle Labs 開發(fā)的一種 AOT 編譯器,應(yīng)用所需的 class 依賴項(xiàng)及 runtime 庫打包編譯生成一個(gè)單獨(dú)可執(zhí)行文件。具有高效的 startup 及較小的運(yùn)行時(shí)內(nèi)存開銷的優(yōu)勢。

但 GraalVM 并未內(nèi)置只是提供 gu 安裝工具,需要我們單獨(dú)安裝。

- 切換到 jdk 的安裝目錄
⋊> ~ cd $JAVA_HOME/bin/

- 使用gu命令安裝
⋊> ./gu install native-image

初始化 Spring Boot 2.4 項(xiàng)目

Spring Initializr 創(chuàng)建 demo 項(xiàng)目

curl https://start.spring.io/starter.zip -d dependencies=web \
   -d bootVersion=2.4.1 -o graal-demo.zip

先看一下啟動(dòng)基準(zhǔn)數(shù)據(jù) , 單純運(yùn)行空項(xiàng)目 需要 1135 ms 秒

java -jar demo-0.0.1-SNAPSHOT.jar
engine: [Apache Tomcat/9.0.41]
2020-12-18 11:48:36.856 INFO 91457 --- [   main] o.a.c.c.C.[Tomcat].[localhost].[/]  : Initializing Spring embedded WebApplicationContext
2020-12-18 11:48:36.856 INFO 91457 --- [   main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 1135 ms

內(nèi)存占用情況

ps aux | grep demo-0.0.1-SNAPSHOT.jar | grep -v grep | awk '{print $11 "\t" $6/1024"MB" }'
/usr/bin/java	480.965MB

支持 GraalVM

增加相關(guān)依賴,涉及插件較多完整已上傳 Gitee Gist

<!-- 新增的部分,注意需要增加 spring maven 倉庫地址才能下載到-->
<dependency>
 <groupId>org.springframework.experimental</groupId>
 <artifactId>spring-graalvm-native</artifactId>
 <version>0.8.3</version>
</dependency>
<dependency>
 <groupId>org.springframework</groupId>
 <artifactId>spring-context-indexer</artifactId>
</dependency>

<!--需要添加 spring maven 倉庫下載 spring-graalvm-native-->
<repositories>
 <repository>
  <id>spring-milestones</id>
  <name>Spring Milestones</name>
  <url>https://repo.spring.io/milestone</url>
 </repository>
</repositories>

Main 方法修改,增加屬性 proxyBeanMethods = false

@SpringBootApplication(proxyBeanMethods = false)

使用 native-image 構(gòu)建可執(zhí)行文件

mvn -Pnative package
#構(gòu)建過程比較慢,日志如下
spring.factories files...
[com.example.demo.demoapplication:93430] classlist: 4,633.58 ms, 1.18 GB
 _____      _        _ __   __  _
 / ___/ ____ _____ (_) ____ ____ _   / | / / ____ _ / /_ (_) _ __ ___
 \__ \ / __ \ / ___/ / / / __ \ / __ `/   / |/ / / __ `/ / __/ / / | | / / / _ \
 ___/ / / /_/ / / /  / / / / / / / /_/ /   / /| / / /_/ / / /_ / / | |/ / / __/
/____/ / .___/ /_/  /_/ /_/ /_/ \__, /   /_/ |_/ \__,_/ \__/ /_/ |___/ \___/
  /_/       /____/

...
[com.example.demo.demoapplication:93430]  [total]: 202,974.38 ms, 4.23 GB

編譯結(jié)果

在 targe 目錄生成 名稱為 com.example.demo.demoapplication 可執(zhí)行文件

啟動(dòng)應(yīng)用 這里執(zhí)行的編譯后的可執(zhí)行文件而不是 jar

cd target

./com.example.demo.demoapplication

啟動(dòng)時(shí)間 0.215 seconds

2020-12-18 12:30:40.625 INFO 94578 --- [   main] com.example.demo.DemoApplication   : Started DemoApplication in 0.215 seconds (JVM running for 0.267)

看一下內(nèi)存占用 24.8203MB

ps aux | grep com.example.demo.demoapplication | grep -v grep | awk '{print $11 "\t" $6/1024"MB" }'

./com.example.demo.demoapplication	24.8203MB

數(shù)據(jù)對比

是否引入 GraalVM 內(nèi)存占用 啟動(dòng)時(shí)間
480.965MB 1135 ms
24.8203MB 215 ms

到此這篇關(guān)于Spring Boot 2.4新特性減少95%內(nèi)存占用問題的文章就介紹到這了,更多相關(guān)Spring Boot 2.4新特性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 2021年最新Redis面試題匯總(4)

    2021年最新Redis面試題匯總(4)

    在程序員面試過程中redis相關(guān)的知識(shí)是常被問到的話題。這篇文章主要介紹了幾道Redis面試題,整理一下分享給大家,感興趣的小伙伴們可以參考一下
    2021-07-07
  • java反射獲取和調(diào)用方法

    java反射獲取和調(diào)用方法

    本篇內(nèi)容主要給大家詳細(xì)講解了java反射獲取方法以及調(diào)用方法,需要的朋友參考學(xué)習(xí)一下吧。
    2017-12-12
  • Java字符串詳解的實(shí)例介紹

    Java字符串詳解的實(shí)例介紹

    本篇文章介紹了,在Java中關(guān)于字符串詳解一些實(shí)例操作,需要的朋友參考下
    2013-04-04
  • java實(shí)現(xiàn)客戶管理系統(tǒng)

    java實(shí)現(xiàn)客戶管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)客戶管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • MyBatis-Plus集成Druid環(huán)境搭建的詳細(xì)教程

    MyBatis-Plus集成Druid環(huán)境搭建的詳細(xì)教程

    這篇文章主要介紹了MyBatis-Plus集成Druid環(huán)境搭建的詳細(xì)教程,需要的朋友可以參考下
    2020-08-08
  • 詳解Mybatis的緩存

    詳解Mybatis的緩存

    這篇文章主要介紹了Mybatis緩存的相關(guān)資料,幫助大家更好的理解和使用Mybatis框架,感興趣的朋友可以了解下
    2021-01-01
  • POS機(jī)如何與Java交互的方式探討

    POS機(jī)如何與Java交互的方式探討

    本文深入探討POS機(jī)與Java語言的交互機(jī)制,詳細(xì)介紹了通過RESTfulAPI、Socket編程和消息隊(duì)列等方式實(shí)現(xiàn)數(shù)據(jù)交換和功能調(diào)用,文章還包含了代碼示例、狀態(tài)圖與關(guān)系圖,幫助開發(fā)者理解和實(shí)現(xiàn)POS機(jī)與Java之間的高效交互
    2024-09-09
  • MyBatis中Mapper的注入問題詳解

    MyBatis中Mapper的注入問題詳解

    這篇文章主要介紹了MyBatis中Mapper的注入問題,我知道在 SpringBoot 體系中,MyBatis 對 Mapper 的注入常見的方式有 2 種,具體哪兩種方法跟隨小編一起看看吧
    2021-09-09
  • Java中的byte & 0xff到底有什么作用?

    Java中的byte & 0xff到底有什么作用?

    這篇文章主要介紹了Java中的byte & 0xff到底有什么作用,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • java中最大的整數(shù)用法分析

    java中最大的整數(shù)用法分析

    這篇文章主要介紹了java中最大的整數(shù)用法,結(jié)合具體實(shí)例形式分析了java計(jì)算類java.math.BigInteger具體使用技巧,需要的朋友可以參考下
    2017-06-06

最新評(píng)論