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数据的分析。

 


相关文章
|
机器学习/深度学习 Shell Python
vmcore自动分析工具
作者:雨庭 ## vmcore分析工具的需求变化 解决内核宕机、修复线上问题以及优化性能瓶颈是各操作系统团队工程师日常工作之一,其中大量工作依赖于crash工具对vmcore进行分析,但是应用规模以及场景的变化对其提出了新的需求。这种需求对开发者和集群运维而言,反映出不同的问题。对于开发者而言,crash工具可以满足查看vmcore中几乎所有数据的需求,例如全局变量、调度子系统
5337 0
|
3月前
|
缓存 监控 算法
吃透 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性能监控工具:推荐与详细用法
919 0
|
存储 安全 Java
深度探索JFR - JFR定位线上问题实例 - JFR导致的雪崩问题定位与解决
深度探索JFR - JFR定位线上问题实例 - JFR导致的雪崩问题定位与解决
深度探索JFR - JFR定位线上问题实例 - JFR导致的雪崩问题定位与解决
|
监控 Java
JVM诊断工具-Greys
Greys为一款“事后工具” ,即服务已经上线了,无法再通过打印日志等方式进行埋点分析,此时可以借助此工具,来跟踪代码执行耗时、堆栈运行情况等。使用Greys,我们无需编写 脚步,它是命令交互式的,直接输入命令指定监控的类、方法。
181 0
|
监控 安全 Oracle
JVM学习(二):JVM监控及诊断工具-命令行篇(上)
Java 作为最流行的编程语言之一,其应用性能诊断一直受到业界广泛关注。可能造成Java应用出现性能问题的因素非常多,例如线程控制、磁盘读写、数据库访问、网络I/o、垃圾收集等。想要定位这些问题,一款优秀的性能诊断工具必不可少。
380 0
JVM学习(二):JVM监控及诊断工具-命令行篇(上)
|
SQL 缓存 监控
监控指标解读和JVM 分析&调优
监控指标解读和JVM 分析&调优
监控指标解读和JVM 分析&调优
|
缓存 监控 Oracle
JFR诊断增强学习笔记
快速学习JFR诊断增强
162 0
JFR诊断增强学习笔记
|
Arthas 存储 监控
|
安全 IDE Java
【Java应用诊断工具】「BTrace」基本概念和原理的介绍(1)
【Java应用诊断工具】「BTrace」基本概念和原理的介绍(1)
167 0