网站首页 > java教程 正文
JFR代表Java Flight Recorder,它是一个用于诊断和分析Java应用程序的基于事件的工具。这个工具最初是在JDK 7中添加的,从那时起它不断得到改进(例如,在JDK 14中,JFR增加了事件流,而在JDK 19中,增加了过滤事件的能力)。在其丰富的事件列表中,JFR可以监控和记录反序列化事件(Deserialization Event)。假设一个像本章第一个问题(问题124)中那样简单的应用程序。我们通过在应用程序的根文件夹中添加以下deserializationEvent.jfc文件来配置JFR以监控此应用程序的反序列化:
<?xml version="1.0" encoding="UTF-8"?>
<configuration version="2.0" description="test">
<event name="jdk.Deserialization">
<setting name="enabled">true</setting>
<setting name="stackTrace">false</setting>
</event>
</configuration>
实际上,这个文件指示JFR监控和记录反序列化事件。接下来,我们使用-XX:StartFlightRecording=filename=recording.jfr来指示JFR在名为recording.jfr的文件中记录输出,并继续使用settings=deserializationEvent.jfc来指向前面列出的配置文件。因此,最终的命令是这个图所示的命令:
图6.2 - 运行JFR 图6.2 - 运行JFR
执行此命令后,您将看到图6.3所示的输出:
图6.3 - 我们应用程序的输出 图6.3 - 我们应用程序的输出
JFR生成了一个名为recording.jfr的文件。我们可以通过JFR CLI轻松查看此文件的内容。命令(jfr print recording.jfr)和输出在图6.4中可用:
图6.4 - 包含反序列化信息的JFR输出 图6.4 - 包含反序列化信息的JFR输出
由于我们的应用程序执行了一个Melon对象的单个序列化/反序列化周期,JFR产生了一个单独的反序列化事件。您可以通过type字段看到对象的类型(这里,Melon)。由于Melon实例不是数组,arrayLength被设置为-1,这意味着数组不适用。objectReferences表示流中的第一个对象引用(因此为1),bytesRead表示从该流中读取的字节数(在这种情况下,78字节)。我们还看到没有过滤器出现,filterConfigured = false,filterStatus = N/A(不适用)。此外,exceptionType和exceptionMessage是N/A。它们不适用,因为没有过滤器出现。它们有助于捕获任何由潜在过滤器引起的异常。
除了JFR CLI,您可以使用更强大的工具来使用Deserialization Event,如JDK Mission Control(https://www.oracle.com/java/technologies/jdk-mission-control.html)和众所周知的Advanced Management Console(https://www.oracle.com/java/technologies/advancedmanagementconsole.html)。
猜你喜欢
- 2024-11-04 快速处理Kafka反序列化错误(kafka自定义反序列化)
- 2024-11-04 又一个反序列化漏洞,我服了...(反序列化漏洞修复方案)
- 2024-11-04 Java代码示例:如何使用 serialVersionUID处理序列化
- 2024-11-04 Java 序列化机制(java序列化过程)
- 2024-11-04 SpringBoot整合Grpc实现跨语言RPC通讯
- 2024-11-04 php和java及python3.10的序列化和反序列化
- 2024-11-04 Java修炼终极指南:133 避免在反序列化时发生DoS攻击
- 2024-11-04 聊聊fastjson反序列化的那些坑(fastjson反序列化原理)
- 2024-11-04 Java序列化 3 连问,这太难了吧(在线序列化工具)
- 2024-11-04 避免使用Java序列化(serializable 防止序列化)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)