怎么利用 Java Flight Recorder (JFR) 捕获并分析生产环境下的 CPU 异常抖动数据
时间:2026-05-04 16:48:51 455浏览 收藏
一分耕耘,一分收获!既然打开了这篇文章《怎么利用 Java Flight Recorder (JFR) 捕获并分析生产环境下的 CPU 异常抖动数据》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!
JFR能每10ms采样线程栈,稳定捕获毫秒级抖动,而top仅显示整体CPU率、jstack为单次快照无法捕捉瞬时尖峰;必须用jcmd动态启动,关键事件包括jdk.ExecutionSample、jdk.JITCompilation、jdk.ThreadStart等。

为什么生产环境 CPU 抖动必须用 JFR 而不是 top 或 jstack
因为 top 只能看到整体 CPU 使用率,jstack 是单次快照、无法捕捉瞬时抖动(比如 200ms 的尖峰),而 JFR 的 jdk.ExecutionSample 事件默认每 10ms 采样一次线程栈,能稳定捕获毫秒级热点方法——这是定位 JIT 逆优化、锁争用、JSON 序列化爆炸等抖动根因的唯一可靠方式。
如何在不重启服务的前提下开启高精度 CPU 录制
生产环境禁止重启,必须用 jcmd 动态启动。关键点在于:采样频率要够高,但不能压垮 JVM;录制时间要覆盖抖动窗口,又不能无限写盘。
- 先查进程 ID:
jcmd -l - 启动 30 秒高频录制(含 JIT 和线程事件):
jcmdJFR.start name=cpu-burst settings=profile duration=30s filename=/tmp/cpu-burst.jfr maxsize=50M - 若已知抖动周期(如每 5 分钟一次),可用
delay=4m30s延迟启动,避免提前录制浪费空间 - 务必加
maxsize=50M,否则环形缓冲区溢出可能丢掉抖动前的关键 JIT 逆优化事件
哪些 JFR 事件对分析 CPU 抖动最关键
抖动不是单纯“CPU 高”,而是某类事件集中爆发。只看 jdk.CPULoad 没用,必须关联以下三类事件:
jdk.ExecutionSample:定位具体哪行代码在抖动期间被采样最多(火焰图基础)jdk.JITCompilation和jdk.JITUncompilation:确认是否发生 C2 逆优化(常见于 JSON 库分支预测失败)jdk.ThreadStart和jdk.JavaThreadPark:检查是否因线程池扩容导致大量线程创建/阻塞
如果 jdk.JITUncompilation 事件在抖动开始前 1–2 秒密集出现,基本可锁定是 JIT 导致的瞬时性能坍塌。
用命令行快速验证抖动时刻的热点方法(不用 JDK Mission Control)
JDK Mission Control 在生产环境常不可用,jfr CLI 工具足够做初步判断:
- 导出抖动期间的执行样本:
jfr print --events jdk.ExecutionSample --begin "2026-04-18T05:28:10" --end "2026-04-18T05:28:12" cpu-burst.jfr > samples.txt - 统计最频繁的方法调用栈:
grep "stackTrace" samples.txt | sort | uniq -c | sort -nr | head -10 - 重点看是否集中出现在
com.fasterxml.jackson.、java.util.regex.或自定义的xxxService.process()上
真正容易被忽略的是:JFR 默认不记录 native 方法栈(如 JNI 调用),如果抖动发生在 Netty 的 epoll_wait 或数据库驱动 native 层,jdk.ExecutionSample 会显示为 Unknown —— 这时得结合 perf record -g -p 补充采集。
今天关于《怎么利用 Java Flight Recorder (JFR) 捕获并分析生产环境下的 CPU 异常抖动数据》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
175 收藏
-
185 收藏
-
317 收藏
-
487 收藏
-
402 收藏
-
202 收藏
-
468 收藏
-
455 收藏
-
251 收藏
-
113 收藏
-
409 收藏
-
411 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习