JFR诊断增强学习笔记

简介: 快速学习JFR诊断增强

开发者学堂课程【JFR诊断增强:JFR诊断增强】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/57

JFR诊断增强


一、概览

1、历史

JFR技术最早起源于JRockit,这项技术最初被设计用于收集虚拟机的各项性能指标,帮助提高虚拟机的性能。在Oracle收购后,这项技术被合并后入OracleJDK中成为商业特性-JDK 7u4+。

最早发布在OracleJDK,期中用户没有办法在生长环境免费使用,幸运的是在2018年,这项技术正式开源于OpenJDK11中,两年后在多个公司的努力下JFR被移植到主流版本OpenJDK8u中,开发者可以在生产环境中免费使用。

2、JFR是什么

JFR是基于事件的数据收集、tracing框架,同时他的完整实践内建于Jdk中。同时,他是一个低开销、生产级别可用的工具,在默认配置下,开销能够控制住2%以内。JFR提供了一套完成的Java API,能够帮助用户自定义和消费事件同时控制JFR的各种行为。

3、优势

相对于传统的Java应用数据收集方案(MX Bean、Java/Native Agent) , JFR的优势:

1、一套标准的API, 允许用户自定义事件

2、默认提供数据持久化和磁盘rotate的能力

3、完善的内存消耗控制策略,高效压缩的二进制数据格式

4、可以收集JVM内部最底层的信息, 传统的方案几乎无法低开销地实现

5、应用异常退出时,仍然可以保证数据的完整性和一致性,保证最终的数据能够正常被解析

6、使用场景:在线的性能分析,问题排查以及持续监控 Profiling&Troubleshooting&Monitoring

image.png

从图中我们可以看出JFR相对于常用的日字记录组件在性能上有着质的提升。

二、基础

1、Event

image.png

对于所有JFR事件来说,有着统一的格式,除了事件大小以及事件ID这类基础信息外,每个事件中还包含了开始时间,消耗时间以及所属现场的ID等等消息,在实线上,JFR为了存储空间的使用效率,使用了变长枕术压缩算法。

image.png

JFR为了提高记录事件的效率,能够在最大程度降低开销,在实线上,每个需要记录JFR事件的现成,都会维护自己的缓存用于记录局部的事件,当局部缓存满后,会将其中内容拷贝到全剧缓存中,最后会被刷出到磁盘文件中,而每一个磁盘文件中的内容都能够被单独解析,因为他包含了所有的数据,文件内容也使用了自描述的格式,保证了数据的完整性和一致性。

image.png

JDK默认提供了超过140个的内置事件,覆盖了各个模块,比如在环境角度,用户能够通过JFR收集到os、cpu层面的数据,在执行角度,用户能搜集到网络文件io等数据以及电动站的数据,在gvm角度,用户能够收集到内加载、垃圾回收器以及及时编译器的数据。

1、Api

image.png

API是一套核心的注解,这套注解能够帮助用户自定义事件,比如用户能够通过内幕注解来定义事件的名称,通过Enabled的注解来定义事件,是否被默认打开,通过StackTrace注释来定义事件是否需要记录站的信息,任务通过这套核心注解以及基础类库,能够完成自定义事件的定义。

image.png

例:图中定义了一个“Hello JFR”事件里面包含了一个message字段,用户能够通过API完成事件的记录。首先用户需要创建一个事件对象,然后通过begin和commit API,来完成事件的记录。

1、Command

image.png

在启动阶段JFR提供了一个参数,能够帮助用户在启动阶段开启一次JFR的记录,同时提供了jcommand的几个命令来帮助用户在运行期间来控制JFR的行为,最后他也提供了JFR命令,来帮助用户打印转储文件中的JFR事件信息。

例子:

image.png

首先在本地环境准备一个支持JFR的JDK,图片中提供了openJDK 15,用户可以选择openJDK8u 262之后的版本或者openJDK 11以及以上的版本,用来进行演示。

image.png

在启动参数中增加StartFlatRecording参数来开启一次记录,在demo中通过name来标注这次记录的名称叫demo,在启动之后会有一段录制输出,来标记这次飞行记录的生效。

image.png

在期间,可以通过JFR.check命令来检查我们记录的配置信息,图中我们可以看出这次记录会去记录各类事件,比如ActRecording事件等。

image.png

在运行一段时间以后,我们能通过dump命令将这期间采集到的JFR事件dump到文件中,我们需要指定recording的名字以及目标,dump文件的路径,最终我们可以从图中看到文件大小为420k。

image.png

有了dump文件,我们就可以用JFR命令输出文件中的事件信息,图中使用了summary命令,可以看到文件中各类事件的基础信息,例如monitorwait事件总共发生了4148次,占用了约100k的大小,用户也可以用print命令来打印更详细的信息。

一、监控

image.png

JFR最初被设计用来问题排查和性能分析上,为了能够让JFR应用于持续监控中,Oracle开源了JEP 349特性:JFR Event Streaming,这个特性提拱了一系列的API,能够让用户连续消费JFR事件,保证额外的开销控制在1%以内,目前已经在openJDK14中正式开源,而阿里巴巴Dragonwell 8.5.4也将这个特性集成进来,从图中我们可以看到,用户能够通过recordingString API以及eventString API来进行特定事件的特定操作。

1、Visualization

在可视化角度,官方提供了JDK mission control 一款桌面软件来帮助用户来进行JFR文件的分析。

在生产环境,我们能够通过agent将JFR数据转换成指标数据,通过目前比较流行的可视化工具,比如granafa进行JFR数据的分析。


相关文章
|
存储 数据采集 人工智能
以Trace为核心的根因分析概述
近期一直在学习和复现“根因分析”领域的相关文章,在这里跟大家一起分享下相关内容。这里不在赘述关于“可观测性”和“AIOps”的重要性和必要性,也不过多的陈述在“复杂系统”中进行快速根因诊断的必要性,直接进入到相关算法和系统设计部分。
1562 0
以Trace为核心的根因分析概述
|
4月前
|
缓存 监控 算法
吃透 JVM 诊断方法与工具使用
【8月更文挑战第4天】深入了解并掌握JVM诊断需把握几大要点:1) 熟悉JVM内存模型,如堆、栈及方法区;2) 掌握垃圾回收机制与算法;3) 运用工具如`jps`(查看Java进程)、`jstat`(监控运行状态)、`jmap`(生成堆快照)、`jhat`(分析堆快照)、`jstack`(检查线程栈); 4) 利用专业工具如Eclipse Memory Analyzer分析堆转储文件查找内存泄漏; 5) 动态监控与调整JVM参数; 6) 结合日志分析性能瓶颈。通过实战案例加深理解,有效应对JVM性能问题。
|
监控 Oracle 数据可视化
深度解析JVM性能监控工具:推荐与详细用法
深度解析JVM性能监控工具:推荐与详细用法
1005 0
|
存储 安全 Java
深度探索JFR - JFR定位线上问题实例 - JFR导致的雪崩问题定位与解决
深度探索JFR - JFR定位线上问题实例 - JFR导致的雪崩问题定位与解决
深度探索JFR - JFR定位线上问题实例 - JFR导致的雪崩问题定位与解决
|
监控 Java
JVM诊断工具-Greys
Greys为一款“事后工具” ,即服务已经上线了,无法再通过打印日志等方式进行埋点分析,此时可以借助此工具,来跟踪代码执行耗时、堆栈运行情况等。使用Greys,我们无需编写 脚步,它是命令交互式的,直接输入命令指定监控的类、方法。
184 0
|
监控 安全 Oracle
JVM学习(二):JVM监控及诊断工具-命令行篇(上)
Java 作为最流行的编程语言之一,其应用性能诊断一直受到业界广泛关注。可能造成Java应用出现性能问题的因素非常多,例如线程控制、磁盘读写、数据库访问、网络I/o、垃圾收集等。想要定位这些问题,一款优秀的性能诊断工具必不可少。
388 0
JVM学习(二):JVM监控及诊断工具-命令行篇(上)
|
缓存 监控 Oracle
JFR诊断增强学习笔记
快速学习JFR诊断增强
166 0
JFR诊断增强学习笔记
|
Arthas 存储 监控
|
安全 IDE Java
【Java应用诊断工具】「BTrace」基本概念和原理的介绍(1)
【Java应用诊断工具】「BTrace」基本概念和原理的介绍(1)
178 0
|
存储 缓存 监控
深度探索JFR - JFR详细介绍与生产问题定位落地 - 1. JFR说明与启动配置(上)
深度探索JFR - JFR详细介绍与生产问题定位落地 - 1. JFR说明与启动配置(上)
深度探索JFR - JFR详细介绍与生产问题定位落地 - 1. JFR说明与启动配置(上)