当前位置:首页 > 科技  > 软件

Spring Boot 3.3.0 新特性| 使用 CDS 优化启动时间

来源: 责编: 时间:2024-06-05 17:46:54 249观看
导读一、CDS 是什么?类数据共享 (CDS) 是一项 JVM 功能,可帮助减少 Java 应用程序的启动时间和内存占用。从 JDK 12 开始,默认的 CDS 归档文件与 Oracle JDK 二进制文件一起预打包。笔者测试使用的 OpenJDK 64-Bit Server VM Z

一、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 的。ciS28资讯网——每日最新资讯28at.com

二、如何使用

2.1 训练

要使用它,您应该首先以分解形式对应用程序执行训练运行:ciS28资讯网——每日最新资讯28at.com

$ 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

这将创建一个  application 目录并生成 application.jsa,只要应用程序未更新,就可以重复使用。ciS28资讯网——每日最新资讯28at.com

2.2 使用

要使用缓存,您需要在启动应用程序时添加一个额外的 -XX:SharedArchiveFile 参数:ciS28资讯网——每日最新资讯28at.com

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

三、效果

为了测试 CDS,笔者使用 Spring Boot initializr 生成了一个 demo 项目。下面是 CDS 训练后的 application 目录的结构:ciS28资讯网——每日最新资讯28at.com

$ tree applicationapplication|-- 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.jar1 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 WebApplicationContext2024-05-31T08:53:40.949+08:00  INFO 14832 --- [demo] [           main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 921 ms2024-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 秒。ciS28资讯网——每日最新资讯28at.com

3.2 使用 CDS 运行

需要先 cd 到训练的 application 目录。ciS28资讯网——每日最新资讯28at.com

$ 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 WebApplicationContext2024-05-31T08:53:16.273+08:00  INFO 21444 --- [demo] [           main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 419 ms2024-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 秒。效果还是非常明显的。ciS28资讯网——每日最新资讯28at.com

四、总结

CDS、CRaC 和 GraalVM,这三种技术都有助于提高Java程序的启动速度,但它们的应用场景和优化方式有所不同。CDS 通过共享类数据来加速启动,CRaC 通过运行时优化来提升性能,而 GraalVM 则通过 AOT 编译来实现快速启动和高效运行。作为开发者,我们可以根据具体需求选择合适的技术来优化 Java 程序的启动时间。ciS28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-92185-0.htmlSpring Boot 3.3.0 新特性| 使用 CDS 优化启动时间

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 大模型驱动下智能化变革,软件行业迎来新机遇

下一篇: 什么是 OpenTiny?有什么特点?如何用?

标签:
  • 热门焦点
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 一文搞定Java NIO,以及各种奇葩流

    大家好,我是哪吒。很多朋友问我,如何才能学好IO流,对各种流的概念,云里雾里的,不求甚解。用到的时候,现百度,功能虽然实现了,但是为什么用这个?不知道。更别说效率问题了~下次再遇到,
  • 消息称小米汽车开始筛选交付中心:需至少120个车位

    IT之家 7 月 7 日消息,日前,有微博简介为“汽车行业从业者、长三角一体化拥护者”的微博用户 @长三角行健者 发文表示,据经销商集团反馈,小米汽车目前
  • 2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • AI芯片初创公司Tenstorrent获三星和现代1亿美元投资

    Tenstorrent是一家由芯片行业资深人士Jim Keller领导的加拿大初创公司,专注于开发人工智能芯片,该公司周三表示,已经从现代汽车集团和三星投资基金等
  • 7月4日见!iQOO 11S官宣:“鸡血版”骁龙8 Gen2+200W快充加持

    上半年已接近尾声,截至目前各大品牌旗下的顶级旗舰都已悉数亮相,而下半年即将推出的顶级旗舰已经成为了数码圈爆料的主流,其中就包括全新的iQOO 11S系
Top