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

Spring Boot 3.3.0 新特性| 使用 CDS 優(yōu)化啟動時間

開發(fā) 前端
CDS、CRaC 和 GraalVM,這三種技術都有助于提高Java程序的啟動速度,但它們的應用場景和優(yōu)化方式有所不同。CDS 通過共享類數據來加速啟動,CRaC 通過運行時優(yōu)化來提升性能,而 GraalVM 則通過 AOT 編譯來實現(xiàn)快速啟動和高效運行。

一、CDS 是什么?

類數據共享 (CDS) 是一項 JVM 功能,可幫助減少 Java 應用程序的啟動時間和內存占用。從 JDK 12 開始,默認的 CDS 歸檔文件與 Oracle JDK 二進制文件一起預打包。筆者測試使用的 OpenJDK 64-Bit Server VM Zulu21.34+19-CA (build 21.0.3+9-LTS, mixed mode, sharing)它也是支持 CDS 的。

二、如何使用

2.1 訓練

要使用它,您應該首先以分解形式對應用程序執(zhí)行訓練運行:

$ java -Djarmode=tools -jar my-app.jar extract --destination application

$ cd application

$ java -XX:ArchiveClassesAtExit=application.jsa -Dspring.context.exit=onRefresh -jar my-app.jar

這將創(chuàng)建一個  application 目錄并生成 application.jsa,只要應用程序未更新,就可以重復使用。

2.2 使用

要使用緩存,您需要在啟動應用程序時添加一個額外的 -XX:SharedArchiveFile 參數:

$ java -XX:SharedArchiveFile=application.jsa -jar my-app.jar

三、效果

為了測試 CDS,筆者使用 Spring Boot initializr 生成了一個 demo 項目。下面是 CDS 訓練后的 application 目錄的結構:

$ tree application
application
|-- application.jsa
|-- demo-0.0.1-SNAPSHOT.jar
`-- lib
    |-- jackson-annotations-2.17.1.jar
    |-- jackson-core-2.17.1.jar
    |-- jackson-databind-2.17.1.jar
    |-- jackson-datatype-jdk8-2.17.1.jar
    |-- jackson-datatype-jsr310-2.17.1.jar
    |-- jackson-module-parameter-names-2.17.1.jar
    |-- jakarta.annotation-api-2.1.1.jar
    |-- jul-to-slf4j-2.0.13.jar
    |-- log4j-api-2.23.1.jar
    |-- log4j-to-slf4j-2.23.1.jar
    |-- logback-classic-1.5.6.jar
    |-- logback-core-1.5.6.jar
    |-- micrometer-commons-1.13.0.jar
    |-- micrometer-observation-1.13.0.jar
    |-- slf4j-api-2.0.13.jar
    |-- snakeyaml-2.2.jar
    |-- spring-aop-6.1.8.jar
    |-- spring-beans-6.1.8.jar
    |-- spring-boot-3.3.0.jar
    |-- spring-boot-autoconfigure-3.3.0.jar
    |-- spring-boot-jarmode-tools-3.3.0.jar
    |-- spring-context-6.1.8.jar
    |-- spring-core-6.1.8.jar
    |-- spring-expression-6.1.8.jar
    |-- spring-jcl-6.1.8.jar
    |-- spring-web-6.1.8.jar
    |-- spring-webmvc-6.1.8.jar
    |-- tomcat-embed-core-10.1.24.jar
    |-- tomcat-embed-el-10.1.24.jar
    `-- tomcat-embed-websocket-10.1.24.jar

1 directory, 32 files

3.1 直接運行 demo-0.0.1-SNAPSHOT.jar

$ java -jar demo-0.0.1-SNAPSHOT.jar
  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/

 :: Spring Boot ::                (v3.3.0)

2024-05-31T08:53:39.964+08:00  INFO 14832 --- [demo] [           main] com.example.demo.DemoApplication         : Starting DemoApplication v0.0.1-SNAPSHOT using Java 21.0.3 with PID 14832 (D:\test\demo\target\demo-0.0.1-SNAPSHOT.jar started by L.cm in D:\test\demo\target)
2024-05-31T08:53:39.967+08:00  INFO 14832 --- [demo] [           main] com.example.demo.DemoApplication         : No active profile set, falling back to 1 default profile: "default"
2024-05-31T08:53:40.893+08:00  INFO 14832 --- [demo] [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port 8888 (http)
2024-05-31T08:53:40.908+08:00  INFO 14832 --- [demo] [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2024-05-31T08:53:40.908+08:00  INFO 14832 --- [demo] [           main] o.apache.catalina.core.StandardEngine    : Starting Servlet engine: [Apache Tomcat/10.1.24]
2024-05-31T08:53:40.948+08:00  INFO 14832 --- [demo] [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2024-05-31T08:53:40.949+08:00  INFO 14832 --- [demo] [           main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 921 ms
2024-05-31T08:53:41.257+08:00  INFO 14832 --- [demo] [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port 8888 (http) with context path '/'
2024-05-31T08:53:41.274+08:00  INFO 14832 --- [demo] [           main] com.example.demo.DemoApplication         : Started DemoApplication in 1.702 seconds (process running for 2.143)

我們可以在日志 Started DemoApplication in 1.702 seconds 看到啟動耗時為 1.702 秒。

3.2 使用 CDS 運行

需要先 cd 到訓練的 application 目錄。

$ java -XX:SharedArchiveFile=application.jsa -jar demo-0.0.1-SNAPSHOT.jar
  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/

 :: Spring Boot ::                (v3.3.0)

2024-05-31T08:53:15.828+08:00  INFO 21444 --- [demo] [           main] com.example.demo.DemoApplication         : Starting DemoApplication v0.0.1-SNAPSHOT using Java 21.0.3 with PID 21444 (D:\test\demo\target\application\demo-0.0.1-SNAPSHOT.jar started by L.cm in D:\test\demo\target\application)
2024-05-31T08:53:15.830+08:00  INFO 21444 --- [demo] [           main] com.example.demo.DemoApplication         : No active profile set, falling back to 1 default profile: "default"
2024-05-31T08:53:16.244+08:00  INFO 21444 --- [demo] [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port 8888 (http)
2024-05-31T08:53:16.249+08:00  INFO 21444 --- [demo] [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2024-05-31T08:53:16.249+08:00  INFO 21444 --- [demo] [           main] o.apache.catalina.core.StandardEngine    : Starting Servlet engine: [Apache Tomcat/10.1.24]
2024-05-31T08:53:16.272+08:00  INFO 21444 --- [demo] [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2024-05-31T08:53:16.273+08:00  INFO 21444 --- [demo] [           main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 419 ms
2024-05-31T08:53:16.425+08:00  INFO 21444 --- [demo] [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port 8888 (http) with context path '/'
2024-05-31T08:53:16.431+08:00  INFO 21444 --- [demo] [           main] com.example.demo.DemoApplication         : Started DemoApplication in 0.722 seconds (process running for 0.885)

我們可以在日志 Started DemoApplication in 0.722 seconds 看到啟動耗時比直接啟動少了將近 1 秒。效果還是非常明顯的。

四、總結

CDS、CRaC 和 GraalVM,這三種技術都有助于提高Java程序的啟動速度,但它們的應用場景和優(yōu)化方式有所不同。CDS 通過共享類數據來加速啟動,CRaC 通過運行時優(yōu)化來提升性能,而 GraalVM 則通過 AOT 編譯來實現(xiàn)快速啟動和高效運行。作為開發(fā)者,我們可以根據具體需求選擇合適的技術來優(yōu)化 Java 程序的啟動時間。

責任編輯:武曉燕 來源: JAVA架構日記
相關推薦

2024-02-26 00:00:00

GolangRedisDocker

2025-06-19 09:53:30

Spring性能優(yōu)化服務器

2013-03-04 10:20:23

JVM優(yōu)化eclipseJVM

2020-02-12 08:50:05

Linux命令啟動時間

2009-02-18 16:34:32

優(yōu)化Windows啟動時間

2013-03-04 10:59:47

eclipseJVM

2018-06-06 14:30:38

Spring BootApplication事件

2022-11-08 07:46:28

record類聲明代碼

2025-04-16 10:03:40

開發(fā)Spring應用程序

2022-10-26 07:14:25

Spring 6Spring業(yè)務

2022-05-04 17:50:51

Linux

2009-06-24 09:22:04

Spring2.5新特

2018-05-30 15:10:24

Spring BootList類型

2025-04-29 07:44:26

配置校驗機制

2024-10-11 11:32:22

Spring6RSocket服務

2009-06-15 16:15:37

Spring2.0新特

2009-06-18 15:40:07

Spring Batc

2023-09-27 08:14:56

2024-12-16 08:10:00

Spring開發(fā)

2023-06-02 16:24:46

SpringBootSSM
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一区成人 | 久久网亚洲 | 精国产品一区二区三区 | 日韩欧美在线视频播放 | 精品美女| 一级片av | 狠狠躁天天躁夜夜躁婷婷老牛影视 | 丝袜天堂 | 成人av在线播放 | 日韩一区在线播放 | 亚洲国产精品99久久久久久久久 | 久久久久久久久久久久久九 | 日韩欧美国产一区二区三区 | 亚洲不卡视频 | eeuss国产一区二区三区四区 | 自拍视频一区二区三区 | 欧美亚洲视频在线观看 | 亚洲成人999 | 国产91丝袜在线18 | 欧美激情在线播放 | 麻豆精品一区二区三区在线观看 | 午夜天堂精品久久久久 | 国产精品免费在线 | 久草新在线 | 国产婷婷精品av在线 | 欧美99 | 97人人澡人人爽91综合色 | 精品国产青草久久久久福利 | 国产亚洲精品久久午夜玫瑰园 | 9999久久 | 午夜成人免费视频 | 精品免费| 久久免费精品 | 国产精品久久久久久久久久免费看 | 国产成人在线视频免费观看 | 久久久久久久久久久福利观看 | 欧美9999| 亚洲精品电影网在线观看 | 伊人久久在线 | 最新91在线 | 自拍视频在线观看 |