Java Leyden可3倍提高JVM启动和预热时间

Leyden 存储库的目的是对 Java 程序的启动时间、达到峰值性能的时间和占用空间进行原型改进 。

Leyden 原型包含许多优化,将工作从运行时转移到早期阶段,这些阶段称为_训练运行_。在训练运行中,我们根据对应用程序实际行为的观察,预先计算各种信息,并将字节码预编译为本机代码。

Leyden repo 密切跟踪 JDK 主线开发。我们通常只比主线JDK repo晚几周。我们在 JDK 主线上实现了以下改进:

  • 统一缓存数据存储(JDK-8320264) :这是对CDS 的增强:
    • 除了类元数据和堆对象之外,现在 CDS 还可以用于存储分析数据以及已编译的 Java 方法。
    • 我们简化了 CDS 档案的创建,以便您可以轻松地在 Java 应用程序中使用 CDS。
    • 该功能可通过新的 VM 标志访问-XX:CacheDataStore。
  • CDS 档案中的已加载类 (JDK-8315737):这使 JVM 能够在应用程序启动时立即将类置于_已加载_状态。因此,我们可以用相当简化的假设来实现许多其他时间移位优化。
    • 可以使用新的 VM 标志来访问此功能-XX:+PreloadSharedClasses。(注意,当 JDK-8315737 集成到 JDK 主线时,此标志将被重命名)。
  • CDS 档案中的方法配置文件 (JDK-8325147):我们将训练运行中的方法配置文件存储在 CDS 档案中,从而使 JIT 能够在预热期间更早开始编译。因此,Java 应用程序可以更快地达到最佳性能。
    • 该功能由新的 VM 标志-XX:+RecordTraining和启用-XX:+ReplayTraining。
  • 提前解析常量池条目:新的 VM 标志-XX:+ArchiveFieldReferences, -XX:+ArchiveMethodReferences使得-XX:+ArchiveInvokeDynamic在训练运行期间解析许多常量池条目成为可能。这允许应用程序更快地启动。此外,已解析的常量池条目的存在允许 AOT 编译器生成更好的代码。
  • Java 方法的提前编译:训练运行期间经常使用的方法可以编译并与 CDS 档案一起存储。因此,只要应用程序在生产运行中启动,其方法就可以在本地执行。
    • -XX:+StoreCachedCode此功能由新的 VM 标志、-XX:+LoadCachedCode和启用-XX:CachedCodeFile。
    • 目前,本机代码存储在单独的文件中,但我们的计划最终将本机代码存储在 CDS 存档文件中。
  • 提前生成动态代理:动态代理经常被流行的应用程序框架使用。我们可以通过提前生成这些代理来缩短启动时间。
    • 该功能由新的 VM 标志启用-XX:+ArchiveDynamicProxies。
  • 提前生成反射数据:反射数据(例如 的实例 java.lang.reflect.Method)由 JVM 生成以支持java.lang.reflect操作。我们可以提前生成这些数据以改善启动。
    • 该功能由新的 VM 标志启用-XX:+ArchiveReflectionData。
  • 类加载器查找缓存:有时应用程序框架可能会按名称执行多次类查找(使用Class.forName()等)。此优化允许快速完成此类查找,而无需扫描类路径。
    • 该功能由新的 VM 标志启用-XX:+ArchiveLoaderLookupCache。

https://www.jdon.com/73771.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/841884.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IP编址、进制转换、IP地址分类、变长子网掩码VLSM、无类域间路由CIDR

前言 网络层位于数据链路层与传输层之间。网络层中包含了许多协议,其中最为重要的协议就是IP协议。网络层提供了IP路由功能。理解IP路由除了要熟悉IP协议的工作机制之外,还必须理解IP编址以及如何合理地使用IP地址来设计网络。 IP编址 每个网段上都有两…

Java的类路径究竟是什么?

回答 问了chatgpt这个问题,首先类路径的定义是: 是指一组路径,这些路径告诉Java虚拟机(JVM)和类加载器在哪里可以找到应用程序所需的类和资源文件。说白了就是在运行java程序的时候需要先将java源代码编译成class文件…

网络七层模型与云计算中的网络服务

网络七层模型,也称为OSI(Open System Interconnection)模型,是由国际标准化组织(ISO)制定的一个概念性框架,用于描述网络通信过程中信息是如何被封装、传输和解封装的。这一模型将复杂的网络通信…

动态规划常见算法题讲解

爬楼梯问题 爬楼梯问题是经典的动态规划问题,通常问题描述如下: 问题描述:一个人站在楼梯的底部,需要到达楼梯的顶部。总共有 n 级台阶,每次可以向上走一阶或两阶。问有多少种不同的方法可以到达楼梯的顶部。 解决方…

基础IO用户缓冲区 、inode、硬软链接【Linux】

文章目录 用户缓冲区磁盘磁盘分区EXT2文件系统的存储方案 inode软链接硬链接 用户缓冲区 代码一&#xff1a; 1 #include<stdio.h>2 #include<unistd.h>3 #include<string.h> 4 int main()5 {6 const char * fstr &…

基于FIDO2和USBKEY硬件的SSH认证

在 8.2&#xff08;最新为 8.3&#xff09;版本中&#xff0c;OpenSSH 提供了对 FIDO 和 UAF 的支持。从此用户就可以用硬件 USBKEY 证书进行 SSH 原生认证。这样可以实现简捷、有效和安全的 SSH 认证。本文我们就就少一下 FIDO2 以及 OpenSSH 对其的支持&#xff0c;并尝试一下…

MySQL中创建触发器时,语法与创建存储过程或函数的语法有所不同注意

在MySQL中创建触发器时&#xff0c;语法与创建存储过程或函数的语法有所不同。触发器的创建语法需要遵循特定的结构&#xff0c;包括指定触发器的名称、触发时机&#xff08;如AFTER或BEFORE&#xff09;、触发事件&#xff08;如INSERT、UPDATE或DELETE&#xff09;以及触发器…

【调试笔记-20240521-Linux-编译 QEMU/x86_64 可运行的 OpenWrt 固件】

调试笔记-系列文章目录 调试笔记-20240521-Linux-编译 QEMU/x86_64 可运行的 OpenWrt 固件 文章目录 调试笔记-系列文章目录调试笔记-20240521-Linux-编译 QEMU/x86_64 可运行的 OpenWrt 固件 前言一、调试环境操作系统&#xff1a;Ubuntu 22.04.4 LTS编译环境调试目标 二、调…

TCP和UDP的区别及应用场景

区别 TCP是面向连接的传输协议&#xff0c;传输数据时必须建立好连接&#xff0c;UDP是无连接&#xff1b;TCP只支持一对一&#xff0c;UDP支持一对一、一对多、多对一、多对多等场景TCP是可靠的传输协议&#xff0c;传输时可保证无差错、不丢失、不重复、按序到达等&#xff…

XStream使用

简介 官网地址 http://x-stream.github.io 官网教程地址 http://x-stream.github.io/alias-tutorial.html XStream是一个简单的基于Java的类库&#xff0c;用来将Java对象序列化成XML(JSON) 或 反序列化为对象 (即&#xff1a;可以轻易的将Java对象和XML文档相互转换)。XStrea…

ES6 笔记04

01 异步函数的使用 es6推出了一种按照顺序执行的异步函数的方法 async 异步函数 async异步函数可以解决promise封装异步代码,调用时一直then链式编程时比较麻烦的问题 定义异步函数: async function 函数名(){ await 表达式1或者函数的调用1 await 表达式2或者函数的调用2 ...…

esp32-S3 使用自带的大模型,实现本地文字转语言tts

目录 CMakeLists.txt文件中: 初始化以及实际运用代码: 在partitions.csv 内存分配文件中,添加voice_data项

日志的介绍及简单实现

个人主页&#xff1a;Lei宝啊 愿所有美好如期而遇 目录 日志是什么&#xff1f; 为什么需要日志&#xff1f; 实现一个简单日志 时间戳 clock_gettime time & localtime 可变模板参数(使用C语言)&#xff0c;va_start & va_end & vsprintf 宏 __LINE__…

从0入门FreeRTOS之第一节 什么是FreeRTOS?

简介与基本概念 什么是FreeRTOS&#xff1f; FreeRTOS&#xff08;Free Real-Time Operating System&#xff09;是一款开源的实时操作系统&#xff08;RTOS&#xff09;&#xff0c;专为嵌入式系统设计。由Real Time Engineers Ltd.开发和维护&#xff0c;FreeRTOS以其小巧、…

Digital Image Processing System(DIPS)

数字图像处理系统 Digital Image Processing System&#xff08;DIPS&#xff09; 早前版本&#xff1a; ​​​​​​​DIPS_YTPC OCR-CSDN博客

springAi使用教程

springAi使用教程 版本要求 环境版本号 springboot 3.2.4 java 17 springAI 0.8.1 导入依赖 1.步骤1 代码如下&#xff1a; <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</…

给页面元素添加水印

关键步骤 初始化和配置&#xff1a; 组件接受一系列配置参数&#xff0c;如水印文本、字体、颜色、旋转角度等。这些参数用于控制水印的外观和位置。 Canvas绘图&#xff1a; 创建一个隐藏的<canvas>元素。使用Canvas API绘制水印图案&#xff0c;根据配置参数设置文…

数据结构和算法|排序算法系列(二)|冒泡排序

首先需要你对排序算法的评价维度和一个理想排序算法应该是什么样的有一个基本的认知&#xff1a; 《Hello算法之排序算法》 主要内容来自&#xff1a;Hello算法11.3 冒泡排序 我觉得冒泡排序非常有意思&#xff0c;也非常简单&#xff0c;就是不停地交换相邻的元素即可&#…

多天线技术

多天线技术可以分为两类&#xff1a;分集技术和空间复用技术。分集技术利用多天线接收或者发射载有同一信息的信号&#xff0c;提高传输的可靠性。分集技术是将瑞利衰落无线信道换成更加稳定的信道。 发射端未知CSI时的信道容量 发射端已知CSI时的信道容量 信道估计&#xff…

基础—SQL—通用语法及分类

一、SQL的通用基本语法 &#xff08;1&#xff09;SQL语句可以单行或多行书写&#xff08;以分号结尾&#xff09;。 &#xff08;2&#xff09;在编写SQL语句的时候&#xff0c;如果长度比较长&#xff0c;我们可以允许空格/缩进来增强语句的可读性&#xff0c;而且空格或者…