0

0

使用Java Flight Recorder (JFR) 分析JAR文件性能

DDD

DDD

发布时间:2025-09-28 11:58:17

|

761人浏览过

|

来源于php中文网

原创

使用Java Flight Recorder (JFR) 分析JAR文件性能

本文详细介绍了如何在JAR文件上运行Java Flight Recorder (JFR) 进行性能监控与分析。我们将探讨所需的JDK版本、命令行参数配置,以及如何生成JFR记录文件。此外,文章还将指导您使用Java Mission Control (JMC) 工具来解析这些记录,从而洞察垃圾回收、内存分配和热点方法等关键性能指标。

1. Java Flight Recorder (JFR) 简介

java flight recorder (jfr) 是一个功能强大的工具,用于收集运行中的java应用程序的诊断和性能数据。它以极低的开销集成在jvm内部,因此非常适合在生产环境中进行性能监控和故障排查。通过jfr,开发者可以深入了解jvm的内部行为,包括垃圾回收、线程活动、i/o操作、内存分配以及热点方法等,从而有效定位性能瓶颈

2. 前提条件

在JAR文件上运行JFR需要满足以下条件:

  • JDK版本: 推荐使用JDK 11或更高版本。从JDK 11开始,JFR成为OpenJDK的免费功能,并可以直接通过 java 命令进行启动。
  • 目标JAR文件: 需要分析性能的Java应用程序的JAR文件。
  • Java Mission Control (JMC): 用于打开和分析JFR记录文件(.jfr 文件)的图形化工具。您可以从 JDK.java.net/jmc 下载最新版本。

3. 在JAR文件上运行JFR

要在JAR文件上启动JFR并记录性能数据,您可以使用 java 命令配合特定的JVM参数。

3.1 基本启动命令

最基本的JFR启动命令如下所示,它会在应用程序运行结束后生成一个JFR记录文件:

java -XX:StartFlightRecording:filename=dump.jfr -jar your_application.jar

命令解析:

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

  • java:用于启动Java应用程序的命令。
  • -XX:StartFlightRecording::这是一个JVM参数,用于启动JFR。
  • filename=dump.jfr:指定了JFR记录文件的名称和路径。如果未指定路径,文件将生成在当前工作目录下。您可以自定义文件名,例如 my_app_performance.jfr。
  • -jar your_application.jar:这是运行您的Java应用程序的标准方式,your_application.jar 是您需要分析的目标JAR文件。

当您的 your_application.jar 程序正常退出时,dump.jfr 文件将生成在指定位置。

3.2 配置记录参数

JFR提供了丰富的配置选项,允许您精确控制记录的内容和时长。您可以指定记录的持续时间、使用的配置模板等。

常用配置参数:

  • duration=
  • settings=:指定JFR的配置模板。
    • default:默认模板,开销极低,适合长时间监控。
    • profile:分析模板,收集更多详细数据,开销略高,适合短期深度分析。
  • name=:为本次记录指定一个逻辑名称,方便在JMC中识别。
  • maxsize=:指定记录文件的最大大小。当文件达到此大小时,JFR会开始覆盖最旧的数据。
  • maxage=

示例:指定记录时长和使用分析模板

BlackBox AI
BlackBox AI

AI编程助手,智能对话问答助手

下载

以下命令将启动JFR,记录60秒的性能数据,并使用 profile 模板,将记录保存为 my_app_60s_profile.jfr:

java -XX:StartFlightRecording:filename=my_app_60s_profile.jfr,duration=60s,settings=profile -jar your_application.jar

指定要基准测试的内容:

JFR默认收集了非常广泛的性能数据,包括:

  • 垃圾回收 (Garbage Collection): 暂停时间、吞吐量、各代GC事件。
  • 内存分配 (Memory Allocation): 对象分配率、热点分配位置。
  • 热点方法 (Hot Methods): CPU消耗最高的方法调用
  • 线程活动 (Thread Activity): 线程状态、锁竞争、阻塞情况。
  • I/O 操作 (I/O Operations): 文件I/O、网络I/O。
  • JVM 事件 (JVM Events): JIT编译、类加载等。

通过选择不同的 settings 模板(如 default 或 profile),您可以调整收集数据的详细程度。如果需要更精细的控制,您还可以创建自定义的JFR事件配置文件(.jfc 文件),并通过 settings=path/to/my_custom_settings.jfc 来加载。

4. 使用Java Mission Control (JMC) 分析JFR记录

生成 .jfr 文件后,下一步是使用Java Mission Control (JMC) 来可视化和分析这些数据。

  1. 启动JMC: 运行您下载的JMC应用程序。
  2. 打开JFR文件: 在JMC的菜单中选择 "File" -> "Open File...",然后导航到您生成的 .jfr 文件并打开它。
  3. 分析数据: JMC将加载并显示JFR记录中的各种性能数据。您可以通过左侧的导航面板浏览不同的视图,例如:
    • Overview (概览): 提供CPU使用率、内存、GC活动等的高级视图。
    • Memory (内存): 详细的堆使用、GC事件、内存分配图。
    • Threads (线程): 线程活动、锁竞争、线程转储。
    • Methods (方法): 热点方法分析,通常以火焰图(Flame Graph)或调用树的形式展示。
    • Events (事件): 记录的所有JFR事件的列表。

通过这些视图,您可以直观地识别应用程序的性能瓶颈,例如高CPU消耗的方法、频繁的GC暂停、内存泄漏迹象或线程阻塞问题。

5. 注意事项

  • JDK版本兼容性: 确保您的JDK版本支持JFR,并了解不同版本JFR的特性差异。JDK 11及以上版本提供了最便捷的使用体验。
  • 开销: JFR设计为低开销,但选择 profile 模板或长时间记录大量事件仍会带来一定的性能影响。在生产环境中使用时,应根据实际情况选择合适的配置。
  • 文件大小: 长时间或高详细度的JFR记录文件可能会非常大。考虑使用 maxsize 或 maxage 参数来限制文件大小。
  • 安全性: JFR记录可能包含应用程序的敏感信息(如方法名、参数等),请妥善保管记录文件。
  • 自定义事件: 对于更高级的用例,您可以在应用程序中集成JFR API来创建自定义事件,从而记录特定业务逻辑的性能数据。

6. 总结

Java Flight Recorder (JFR) 是一个功能强大且开销极低的Java性能分析工具。通过本文介绍的步骤,您可以轻松地在JAR文件上启动JFR,收集详细的运行时数据,并利用Java Mission Control (JMC) 进行深入分析。掌握JFR的使用将极大地提升您诊断和优化Java应用程序性能的能力,确保您的应用高效稳定运行。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
堆和栈的区别
堆和栈的区别

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

397

2023.07.18

堆和栈区别
堆和栈区别

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

575

2023.08.10

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

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

397

2023.07.18

堆和栈区别
堆和栈区别

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

575

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

503

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

87

2025.12.01

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

223

2023.12.07

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

2

2026.01.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

446

2026.01.28

热门下载

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

精品课程

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

共23课时 | 3万人学习

C# 教程
C# 教程

共94课时 | 7.9万人学习

Java 教程
Java 教程

共578课时 | 52.8万人学习

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

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