JAVA 提速方法——类数据共享 CDS

类数据共享

CDS(Class-Data Sharing) 类数据共享 是一项 JVM 功能,减少 Java 应用的启动时间和内存占用。CDS 作用是让** class 被预处理到归档文件**,Java 程序启动直接带上归档文件,这样 JVM 可直接将归档文件映射到内存,节约应用启动时间

测试环境

Springboot3.3 / JDK17
filemanager-1.1.0.jar 测试用Jar包 (m.jsoft.vip/d/10915)

执行训练

java -Djarmode=tools -jar filemanager-1.1.0.jar extract --destination application
cd application
java -XX:ArchiveClassesAtExit=application.jsa -Dspring.context.exit=onRefresh -jar filemanager-1.1.0.jar

生成缓存目录,结构如下

application
├── application.jsa
├── filemanager-1.1.0.jar
└── lib
    ├── angular-translate-2.9.1.jar
    ├── angularjs-1.5.0.jar
    ├── attoparser-2.0.7.RELEASE.jar
    ├── bootstrap-3.3.6.jar
    ├── bootswatch-paper-3.3.5+4.jar
    ├── commons-compress-1.12.jar
    ├── commons-fileupload-1.3.1.jar
    ├── commons-io-2.2.jar
    ├── commons-lang3-3.14.0.jar
    ├── commons-pool2-2.12.0.jar
    └── unbescape-1.1.6.RELEASE.jar

使用缓存 启动时间 1.0s

java -XX:SharedArchiveFile=application.jsa -jar filemanager-1.1.0.jar

不使用CDS启动 java -jar filemanager-1.1.0.jar 启动时间 1.8s

启动速度提升 50%

使用CDS后,Java应用启动速度有明显提升(近50%),相对于AOT等方式,容易部署,没有副作用。

SQL查询——7种JOIN方法1张图
微信公众号