Java25新特性:JFR CPU时间性能分析

JEP509:该特性是一个实验特性,增强了JFR以便获取更准确的CPU时间信息,目前仅在Linux平台可用。

在这之前,JFR使用的是墙钟时间,无法捕获原生代码如Native 代码的CPU消耗**;**线程阻塞在I/O时,时间仍然在走,并且无法区分线程是真正消耗CPU还是处于等待状态。

JEP 509 引入新的 JFR 事件 jdk.CPUTimeSample,基于线程实际消耗的 CPU 时间。

java 复制代码
public class CPUProfiling {
    void main() {
        IO.println("开始执行计算任务...");
        for (long i = 0; i < 2_000_000_000L; i++) {
            Math.sqrt(Math.log(i + 1));
        }
        IO.println("完成");
    }
}

编译:

java 复制代码
javac --enable-preview --release 25 CPUProfiling.java

运行并记录CPU时间:

java 复制代码
java '-XX:StartFlightRecording=jdk.CPUTimeSample#enabled=true,jdk.CPUTimeSample#throttle=500/s,filename=cpu.jfr' CPUProfiling

执行结果:(非Linux平台,告警CPU time method sampling not supported)

生成jfr文件:

分析结果:

java 复制代码
/jdk/jdk-25.0.2.jdk/Contents/Home/bin/jfr view cpu-time-hot-methods cpu.jfr
java 复制代码
/jdk/jdk-25.0.2.jdk/Contents/Home/bin/jfr summary cpu.jfr

在Linux上执行:

相关推荐
千码君20166 小时前
flutter: 分享一下基于trae cn 构建的过程
java·vscode·flutter·kotlin·trae
weisian1516 小时前
Java并发编程--51-详解RocketMQ:高可靠消息中间件的核心特性与生产实践
java·rocketmq·java-rocketmq·事务消息
Gh0st_Lx6 小时前
【5】深度解构:JVM 垃圾回收机制
java·jvm
Jul1en_6 小时前
【Redis】持久化策略
java·数据库·redis
fox_lht6 小时前
onPaint函数流程图
java·eclipse·流程图
TE-茶叶蛋6 小时前
电商订单id设计思路
java
0xDevNull6 小时前
Spring注解@Requestbody、@Requestparam、@PathVariable
java·后端·spring
budingxiaomoli7 小时前
环境和工程创建
java·spring·springcloud
梦想不只是梦与想7 小时前
java中多态的属性和方法
java·多态属性·多态方法