Java Flight Record 详解

核心概念

Java Flight Record 提供一个低开销的数据收集框架,用于对 Java 应用程序和 HotSpot JVM 进行故障排除。Flight Recorder 记录源自应用程序JVM操作系统事件

Flight Record,顾名思义,相当于飞机黑匣子里保存的飞行记录

事件

JFR在Java应用运行时收集对应发生的事件,主要有三种类型的事件提供给JFR收集:

  • 即时事件:一旦事件发生会立即进行数据记录
  • 持续事件:如果持续时间超过指定阈值则进行数据记录
  • 简单事件:用于记录应用所在系统的活跃指标(例如CPU,内存等)

Java Flight Recorder (JFR) 可以监听和记录各种事件,包括但不限于以下几类:

  1. 方法耗时:JFR 可以记录方法的执行时间,用于分析和优化程序的性能。
  2. 垃圾收集:JFR 可以记录垃圾收集器的活动和性能指标,包括吞吐量、停顿时间和对象分配等。
  3. 线程活动:JFR 可以记录线程的创建、销毁、休眠和唤醒等活动,用于分析并发和线程相关的性能问题。
  4. 锁竞争:JFR 可以记录锁的竞争和等待情况,用于分析多线程程序中的死锁和竞争问题。
  5. I/O 操作:JFR 可以记录文件读写、网络传输等 I/O 操作的性能指标和耗时,用于分析和优化 I/O 性能。
  6. GC 周期:JFR 可以记录整个 GC 周期的信息,包括新生代、老年代和永久代的使用情况和回收效率等。
  7. 内存分配:JFR 可以记录内存的分配和使用情况,包括堆内、堆外和直接内存的分配和释放情况。

除了上述事件,JFR 还支持自定义事件,您可以根据应用程序的需求自定义记录特定事件和指标。这些事件和指标可以帮助开发人员了解应用程序的行为和性能状况,并进行性能优化和故障排查。

缓冲机制和二进制数据格式

线程将事件无锁地写入ThreadLocal缓冲区。一旦ThreadLocal缓冲区填满,它就会被提升为全局内存循环缓冲区系统,该系统维护最新的事件数据。根据配置,最旧的数据要么被丢弃,要么被写入磁盘,从而允许连续保存历史记录

事件模型以little endian base 128的形式编码的二进制格式实现。磁盘上的二进制文件具有扩展名.jfr,并使用保留策略进行维护和控制

作为说明性示例,类加载事件包含描述其发生时间的时间戳、描述时间跨度的持续时间、线程、堆栈跟踪以及三个事件特定有效负载字段、加载的类和关联的类加载器。事件的大小总共为 24 字节。

<memory address>: 98 80 80 00 87 02 95 ae e4 b2 92 03 a2 f7 ae 9a 94 02 02 01 8d 11 00 00
  • 活动规模[98 80 80 00]
  • 事件ID[87 02]
  • 时间戳[95 ae e4 b2 92 03]
  • 期间[a2 f7 ae 9a 94 02]
  • 线程ID[02]
  • 堆栈跟踪 ID[01]
  • 有效负载[字段]
    • 加载类:[0x8d11]
    • 定义类加载器:[0]
    • 启动类加载器:[0]

JFR 诊断

在 JVM 命令启动JFR

-XX:StartFlightRecording

bin/jcmd 工具启动JFR

# 启动JFR
jcmd <pid> JFR.start

# dump
jcmd <pid> JFR.dump filename=recording.jfr

# 停止JFR
jcmd <pid> JFR.stop

命令参数详见 JFR命令参考

JFR 解析

输出jfr文件后,可以使用JDK Mission Control分析工具对各种性能指标进行分析。可以直接使用JFR 解析命令查看摘要信息和事件流

JDK Mission Control

JDK Mission Control是一个强大的性能分析工具,它包含了对JFR文件进行可视化分析的功能。可以使用JDK Mission Control打开JFR文件,查看各种性能指标、方法调用树、线程活动等信息,并进行高级分析和故障排查。

JFR 解析命令

jfr print <filename.jfr>

部分JFR文件的摘要信息和事件流

jdk.CodeCacheStatistics {
  startTime = 16:13:08.344
  codeBlobType = "CodeHeap 'non-nmethods'"
  startAddress = 0x7FE6A1715000
  reservedTopAddress = 0x7FE6A1CA4000
  entryCount = 1134
  methodCount = 0
  adaptorCount = 1046
  unallocatedCapacity = 3.7 MB
  fullCount = 0
}

jdk.CodeSweeperStatistics {
  startTime = 16:13:08.344
  sweepCount = 72
  methodReclaimedCount = 11991
  totalSweepTime = 3.09 s
  peakFractionTime = 208 ms
  peakSweepTime = 208 ms
}

jdk.GCConfiguration {
  startTime = 16:13:08.344
  youngCollector = "N/A"
  oldCollector = "Z"
  parallelGCThreads = 2
  concurrentGCThreads = 1
  usesDynamicGCThreads = true
  isExplicitGCConcurrent = false
  isExplicitGCDisabled = true
  pauseTarget = N/A
  gcTimeRatio = 99
}

使用实例

自动分析结果

自动分析结果

JMC分析

JMC分析

事件浏览器

事件浏览器

HotSpot JVM 中的对象指针压缩

总结

  1. 低开销的性能监控:JFR 是与 JVM 集成的轻量级性能监控工具,可以在不影响应用程序性能的情况下实时收集和记录各种性能数据。与其他性能工具相比,JFR 的性能开销非常低,几乎可以忽略不计
  2. 实时和历史数据记录:使用 JFR,您可以实时记录应用程序的性能数据,例如线程活动、方法执行时间、垃圾收集等。您还可以通过配置持久化设置,将记录的数据保存为 JFR 文件,以供后续分析和排查问题
  3. 低停顿垃圾收集(Low-Pause Garbage Collection):JFR 可以捕获 Java 垃圾收集器的详细信息,包括停顿时间、吞吐量、对象分配等。这些数据可以帮助您了解垃圾收集器的性能特征并进行优化
  4. 生产环境监控:使用 JFR,您可以在生产环境中实时监控应用程序的性能和健康状况。通过收集关键指标,您可以及时发现和解决潜在的问题,避免应用程序性能下降或故障
  5. 高度可定制性:JFR 提供了丰富的配置选项,可以根据您的需求定制性能监控的粒度和数据采集。您可以选择感兴趣的事件、添加自定义事件和属性,以满足您特定的监控需求
  6. 集成与分析工具:JFR 数据可以与 JDK Mission Control 等工具集成,提供直观的可视化界面和高级分析功能。开发人员可以使用这些工具快速定位性能问题,并进行优化

总而言之,Java JFR是一个功能强大且易于使用的性能监控和故障诊断工具,可以帮助开发人员优化Java应用程序的性能,并提高应用程序在生产环境中的稳定性


参考资料:

  1. JEP 328: Flight Recorder
  2. Java Platform, Standard Edition Java Flight Recorder Runtime Guide
  3. JFR-Java Flight Record
  4. JEP 167:基于事件的 JVM 跟踪
  5. JDK Mission Control
  6. 深度探索JFR - JFR详细介绍与生产问题定位落地

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2023-11-27 LeetCode每日一题(子数组的最小值之和)

2023-11-27每日一题 一、题目编号 907. 子数组的最小值之和二、题目链接 点击跳转到题目位置 三、题目描述 给定一个整数数组 arr&#xff0c;找到 min(b) 的总和&#xff0c;其中 b 的范围为 arr 的每个&#xff08;连续&#xff09;子数组。 由于答案可能很大&#xff…

Shopee买家号想要多开怎么解决?

拥有多个Shopee买家号有很多优势。多账号可以帮助卖家获得更多流量、还能帮助提供关键词排名、提高销量等。 但是要管理多个Shopee买家号并非易事。面对不同账号的登录、注销和切换&#xff0c;可能会花费大量的时间和精力。而且&#xff0c;Shopee平台对于使用同一IP地址同时登…

DevEco Studio在预览器上快速定位元素所在的组件代码位置

常规开发过程中 如果我们的组件过多 找对象就会比较困难 我们可以点击如下图指向位置 这边呢 就有一个组件树 我们可以快速定位到当前元素的代码位置 同时你在点元素的时候 代码它也给你标记出来了

仅2万粉,带了2.6万件的货!TikTok Shop美区达人周榜(11.13-11.19)

11月24日&#xff0c;TikTok Shop近日公布了美国市场和英国市场的全托管黑五大促战绩。数据显示&#xff0c;11月14日至11月20日&#xff0c;其美国市场的订单量环比10月20日-10月26日增长了205%。 家居户外热销品有&#xff1a;数码触摸屏相框、毛绒地毯、家居毛毯。黑马商品…

C语言基础篇5:指针(一)

指针是C语言的核心、精髓所在&#xff0c;用好了指针可以在C语言编程中起到事半功倍的效果。指针一方面可以提高程序的编译效率和执行速度&#xff0c;而且还可以通过指针实现动态的存储分配&#xff0c;另一方面使用指针可使程序更灵活&#xff0c;便于表示各种数据结构&#…

学习.NET验证模块FluentValidation的基本用法(续3:ASP.NET Core中的调用方式)

FluentValidation模块支持在ASP.NET Core项目中进行手工或自动验证&#xff0c;主要验证方式包括以下三种&#xff1a;   1&#xff09;手工注册验证类&#xff0c;并在控制器或其它模块中调用验证&#xff1b;   2&#xff09;基于ASP.NET验证管道&#xff08;validation …

CountDownLatch实战应用——批量数据多线程协调异步处理(主线程执行事务回滚)

&#x1f60a; 作者&#xff1a; 一恍过去 &#x1f496; 主页&#xff1a; https://blog.csdn.net/zhuocailing3390 &#x1f38a; 社区&#xff1a; Java技术栈交流 &#x1f389; 主题&#xff1a; CountDownLatch实战应用——批量数据多线程协调异步处理(主线程执行事务…

基于SpringBoot的超市信息管理系

✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目背景介绍&#xff1a; 随着我国经济的不断发…

送PDF书 | 豆瓣9.2分,超250万Python新手的选择!蟒蛇书入门到实践

在此疾速成长的科技元年&#xff0c;编程就像是许多人通往无限可能世界的门票。而在编程语言的明星阵容中&#xff0c;Python就像是那位独领风 骚的超级巨星&#xff0c; 以其简洁易懂的语法和强大的功能&#xff0c;脱颖而出&#xff0c;成为全球最炙手可热的编程语言之一。 …

【第二节:微信小程序 app.json配置】微信小程序入门,以思维导图的方式展开2

以思维导图的方式呈现出来&#xff0c;是不是会更加直观一些呢 如果看不清楚&#xff0c;私信给单发 &#xff1a; 第二节&#xff1a;微信小程序 app.json配置&#xff1a; 包括&#xff1a; window pages tabBar networkTimeout debug 如下图所示&#xff1a; 2、ap…

使用 OpenCV 发现圆角矩形的轮廓

OpenCV - 如何找到圆角矩形的矩形轮廓? 问题: 在图像中,我试图找到矩形对象的圆角轮廓。然而,我对两者的尝试 HoughLinesP 并 findContours 没有产生预期的结果。 我的目标是找到一个类似于以下形状的矩形: 。 代码: import cv2 import matplotlib.pyplot as plt…

亚信科技AntDB数据库与库瀚存储方案完成兼容性互认证

近日&#xff0c;亚信科技AntDB数据库与苏州库瀚信息科技有限公司自主研发的RISC-V数据库存储解决方案进行了产品兼容测试。经过双方团队的严格测试&#xff0c;亚信科技AntDB数据库与库瀚数据库存储解决方案完全兼容、运行稳定。除高可用性测试外&#xff0c;双方进一步开展TP…

[C/C++]数据结构 堆排序(详细图解)

一:前言 在[C/C]数据结构 堆的详解中,介绍了什么是堆,并且完成了堆的实现和一系列接口,包括向上调整法和向下调整法等,接下来小编介绍一个有点量级的排序方法------堆排序,时间复杂度为O(n*lgn) 二:堆排序详解 2.1 方法介绍 1.首先将待排序数组建为大堆,此时堆顶元素就为数组…

Linux操作系统 1.初识Linux

一、Linux学习大致内容 二、操作系统概述 操作系统的作用&#xff1a; 常见操作系统&#xff1a; 1、pc&#xff08;电脑端&#xff09;&#xff1a;windows、Linux、MacOS 2、移动端&#xff1a;Android、ios、鸿蒙系统 总结 1.计算机由哪两个部分组成&#xff1f;、 硬件…

04:2440---内存控制器

目录 一:介绍 1:引入 2:概念 3:通信 A:片选信号 B:片选信号的地址空间范围 ​​​​ 4:地址线 A:不同位数的接法 B:访问原理 C:访问地址 5:时序 1:NOR FLASH A:2440NOR FLASH时序 B:原理/时序图 C:寄存器 6:SDARM A:访问方式 B:原理图 C:BWSCON D:BANKCON…

【Linux系统编程】操作系统详解(什么是操作系统?为什么会存在操作系统?设计操作系统的目的是什么?)

目录 一、前言 二、 什么是操作系统 &#x1f4a6;操作系统的引入 &#x1f4a6;操作系统的概念理解 &#x1f4a6;操作系统设计的目的与定位 &#x1f4a6;总结 二、操作系统之上之下分别有什么 三、深度理解操作系统的“管理” &#x1f4a6;场景理解 &#x1f4a6;操…

视频文件+EasyDarwin做摄像机模拟器模拟RTSP流很方便,还能做成系统服务,方法与流程

之前我看到过一家人工智能做算法的企业&#xff0c;用EasyDarwinFFMPEG做了一个摄像机的模拟器&#xff0c;方法大概是&#xff1a; 用ffmpeg读取mp4等类型的视频文件&#xff08;当然ffmpeg啥都能读取&#xff09;&#xff0c;再以RTSP协议的形式推送给EasyDarwin&#xff1b…

不会提问不打紧,不敢提问才要命

最近在星球里回答了球友提出来的一些问题&#xff0c;我都给了回复&#xff0c;不经过在明确问题、探索问题的过程&#xff0c;对我启发挺大&#xff0c;特此来记录下感受和感悟。 缘起 最近新加入球友提的问题&#xff0c;有几次&#xff0c;我第一时间没看懂&#xff0c;甚…

【沐风老师】3DMAX快速地板屋顶墙面铺设插件使用方法详解

3DMAX快速地板屋顶墙面铺设插件使用教程 3DMAX快速地板屋顶墙面铺设插件&#xff0c;一键生成各种地板、墙面纹理模型&#xff0c;是一款非常实用的室内设计和建筑建模插件。 【适用版本】 3dMax7或更新版本 【安装方法】 该插件无需安装&#xff0c;直接在建模过程中使用&a…

【leetcode】62. 不同路径

题目 一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下图中标记为 “Finish” &#xff09;。 问总共有多少条不同的路径&#xff1f; …