0

0

如何使用JFR(Java Flight Recorder)记录系统运行状态_低开销的生产环境监控

P粉602998670

P粉602998670

发布时间:2026-03-17 08:13:30

|

987人浏览过

|

来源于php中文网

原创

Java 11+ 默认禁用JFR,需显式添加-XX:+FlightRecorder启动参数;jcmd录制须指定name、duration和settings=profile以保障可追溯性与采样精度;分析应使用本地JMC而非浏览器,避免OOM;低开销不等于零开销,避免高频录制。

如何使用jfr(java flight recorder)记录系统运行状态_低开销的生产环境监控

Java 11+ 默认没开 JFR,得手动解锁

JFR 在 Java 8u261+ 和 Java 11+ 是默认禁用的,不是“装了就能用”。不显式启用,jcmd 都看不到录制选项,更别说生成 .jfr 文件。

常见错误现象:jcmd <pid> VM.unlock_commercial_features 报错 “Unknown diagnostic command”,或者 jcmd <pid> JFR.start 直接失败 —— 其实是 JVM 启动时压根没带商业特性开关。

  • Java 8u261+:必须加 JVM 参数 -XX:+UnlockCommercialFeatures -XX:+FlightRecorder
  • Java 11+:去掉 UnlockCommercialFeatures,只留 -XX:+FlightRecorder(该 flag 已默认启用,但某些发行版如 OpenJDK 构建可能仍需显式声明)
  • OpenJDK 17+(如 Temurin、Zulu)通常已内置支持,但生产环境仍建议显式加 -XX:+FlightRecorder,避免被构建脚本或容器镜像覆盖

jcmd 启动录制时别漏掉 name 和 duration

直接敲 jcmd <pid> JFR.start 看似能跑,但默认只录 60 秒、内存缓冲区极小(约 10MB),且没命名 —— 多次启动后你根本分不清哪个 .jfr 对应哪次排查。

使用场景:线上突发 CPU 尖刺、GC 频繁、HTTP 响应变慢,需要“现在立刻录 3 分钟看看”。

立即学习Java免费学习笔记(深入)”;

  • 务必指定 name=xxx,例如 jcmd <pid> JFR.start name=cpu-spike-20240520-1430
  • duration=180s 控制时长,避免无限录制拖垮老年代内存
  • settings=profile(而非默认的 default)提升采样精度:方法调用栈、锁竞争、堆分配热点全都有
  • 慎用 disk=true:默认写内存环形缓冲区(低开销),设为 true 才落盘;但若进程突然挂掉,未刷盘数据就丢了

分析 .jfr 文件时,别在浏览器里硬扛大文件

JFR 录制 5 分钟高负载应用,轻松产出 200MB+ 的 .jfr。用 Chrome 打开 JDK 自带的 JDK Mission Control(JMC)加载没问题,但直接拖进浏览器访问 https://localhost:7070(JFR over HTTP)大概率卡死或 OOM。

NameGPT名称生成器
NameGPT名称生成器

免费AI公司名称生成器,AI在线生成企业名称,注册公司名称起名大全。

下载

性能影响:JMC 后端解析本身吃 CPU 和堆内存,浏览器前端渲染大量事件(比如 10 万次 java.lang.ThreadParkEvent)会触发 JS GC 飙升,界面冻结。

  • 优先用本地 JMC(jmc 命令或双击启动),它对大文件做了流式解析和懒加载
  • 命令行快速筛信息:用 jfr print --events "jdk.CPULoad" --start "2024-05-20T14:30" my.jfr 提取某类事件片段
  • 导出为 CSV 再用 Excel 或 Grafana 分析:在 JMC 里右键图表 → Export → CSV,比截图或肉眼扫快得多

低开销 ≠ 零开销,高频录制反而伤性能

JFR 官方说“平均开销 stacktrace 采样、方法级别 Allocation 跟踪、或每毫秒采一次 CPU,开销会跳到 5~10%,尤其在大量短生命周期对象或高并发线程场景下。

容易踩的坑:有人为“保险起见”在所有 Pod 启动时就常驻开启 JFR,结果发现服务 RT 普遍升高、GC 次数变多 —— 其实是 JFR 缓冲区争用和事件采集干扰了 JIT 编译节奏。

  • 生产环境推荐“按需开启”:只在怀疑问题时启动,录完立刻 JFR.stop name=xxx
  • 避免长期 settings=profile 录制;日常可观测可用轻量 default 配置,仅开 GC、Thread、Socket 事件
  • 检查是否重复启用了多个 recording:jcmd <pid> JFR.check 会列出所有活跃 recording,重复录制等于双倍开销

真正难的是判断“什么时候该开、开多久、开哪些事件”——这没法靠模板,得结合你的服务 SLA、GC 日志模式、以及上次排查时实际看到的瓶颈点来定。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1082

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

851

2023.11.06

python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

19

2026.02.03

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.5万人学习

C# 教程
C# 教程

共94课时 | 11.5万人学习

Java 教程
Java 教程

共578课时 | 83.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号