百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

troubleshoot之:使用JFR分析性能问题

liuian 2025-04-27 14:44 51 浏览

简介

java程序的性能问题分析是一个很困难的问题。尤其是对于一个非常复杂的程序来说,分析起来更是头疼。

还好JVM引入了JFR,可以通过JFR来监控和分析JVM的各种事件。通过这些事件的分析,我们可以找出潜在的问题。

今天我们就来介绍一下对java性能分析比较重要的一些JFR事件。

GC性能事件

一般来说,GC会对java程序的性能操作产生比较重要的影响。我们可以使用jfr监控jdk.GCPhasePause事件。

下面是一个jdk.GCPhasePause的例子:

jfr print --events jdk.GCPhasePause flight_recording_1401comflydeanTestMemoryLeak89268.jfr

输出结果:

jdk.GCPhasePause {
  startTime = 19:51:49.798
  duration = 41.1 ms
  gcId = 2
  name = "GC Pause"
}

通过GCPhasePause事件,我们可以统计总的GC pause时间和平均每一次GC pause的时间。

一般来说GC是在后台执行的,所以GC本身的执行时间我们并不需要关注,因为这并不会影响到程序的性能。我们需要关注的是应用程序因为GC暂停的时间。

考虑下面两种情况,第一种单独的GC导致GC pause时间过长。第二种是总的GC pause时间过长。

如果是第一种情况,那么可能需要考虑换一个GC类型,因为不同的GC类型在pause时间和吞吐量的平衡直接会有不同的处理。同时我们需要减少finalizers的使用。

如果是第二种情况,我们可以从下面几个方面来解决。

  • 增加heap空间大小。heap空间越大,GC的间隔时间就越长。总的GC pause时间就会越短。
  • 尽量减少tmp对象的分配。我们知道为了提升多线程的性能,JVM会使用TLAB技术。一般来说小对象会分配在TLAB中,但如果是大对象,则会直接分配在heap空间中。但是大部分对象都是在TLAB中分配的。所以我们可以同时关注TLAB和TLAB之外的两个事件:jdk.ObjectAllocationInNewTLAB和dk.ObjectAllocationOutsideTLAB。
  • 减少分配频率。我们可以通过jdk.ThreadAllocationStatistics来分析。

同步性能

在多线程环境中,因为多线程会竞争共享资源,所以对资源的同步,或者锁的使用都会影响程序的性能。

我们可以监控jdk.JavaMonitorWait事件。

jfr print --events jdk.JavaMonitorWait flight_recording_1401comflydeanTestMemoryLeak89268.jfr

我们看一个结果:

jdk.JavaMonitorWait {
  startTime = 19:51:25.395
  duration = 2 m 0 s
  monitorClass = java.util.TaskQueue (classLoader = bootstrap)
  notifier = N/A
  timeout = 2 m 0 s
  timedOut = true
  address = 0x7FFBB7007F08
  eventThread = "JFR Recording Scheduler" (javaThreadId = 17)
  stackTrace = [
    java.lang.Object.wait(long)
    java.util.TimerThread.mainLoop() line: 553
    java.util.TimerThread.run() line: 506
  ]
}

通过分析JavaMonitorWait事件,我们可以找到竞争最激烈的锁,从而进行更深层次的分析。

IO性能

如果应用程序有很多IO操作,那么IO操作也是会影响性能的关键一环。

我们可以监控两种IO类型:socket IO和File IO。

相对应的事件有:dk.SocketWrite,jdk.SocketRead,jdk.FileWrite,jdk.FileRead。

代码执行的性能

代码是通过CPU来运行的,如果CPU使用过高,也可能会影响到程序的性能。

我们可以通过监听jdk.CPULoad事件来对CPULoad进行分析。

jfr print --events jdk.CPULoad flight_recording_1401comflydeanTestMemoryLeak89268.jfr

看下运行结果:

jdk.CPULoad {
  startTime = 19:53:25.519
  jvmUser = 0.63%
  jvmSystem = 0.37%
  machineTotal = 20.54%
}

如果jvm使用的cpu比较少,但是整个machine的CPU使用率比较高,这说明了有其他的程序在占用CPU。

如果JVM自己的CPU使用就很高的话,那么就需要找到这个占用CPU的线程进行进一步分析。

其他有用的event

除了上面提到的event之外,还有一些其他有用的我们可以关注的event。

比如线程相关的:jdk.ThreadStart,jdk.ThreadEnd,jdk.ThreadSleep,jdk.ThreadPark。

如果你使用JMC,那么可以很直观的查看JFR的各种事件。

所以推荐大家使用JMC。

本文作者:flydean程序那些事

本文链接:
http://www.flydean.com/jvm-diagnostic-perform-issue/

本文来源:flydean的博客

欢迎关注我的公众号:程序那些事,更多精彩等着您!

相关推荐

电脑硬盘数据恢复工具(电脑硬盘数据恢复多少钱一次)

只要是正版的数据恢复软件都会收费,如果想免费的话可以安装一个迷你兔数据恢复软件试试,因为它提供了200M的免费恢复额度,如果你的恢复需求不大,那就可以免费恢复

u盘有必要分区吗

分区好U盘分区的主要作用是将一个物理上的U盘分为多个逻辑上的独立区域,每个区域可以单独管理和使用。这样做的好处是可以将不同类型的文件分别存放在不同的分区中,提高文件的组织性和管理效率。例如,可以将工作...

优盘怎么做系统启动盘(优盘怎么做系统启动盘教程)

1/4分步阅读将U盘插上电脑,打开运行在电脑上下载好的小白一键重装系统软件,打开前退出所有杀毒软件,避免杀毒软件阻拦操作步骤。点击左侧“制作系统”,然后检测U盘后点击“开始制作”按钮。2/4在选择系统...

win7激活错误0 80072f8f(win7激活时发生错误,错误代码0x80072f8f)
win7激活错误0 80072f8f(win7激活时发生错误,错误代码0x80072f8f)

可以通过修改时间来解决系统提示0x80072F8F错误代码的操作方法。操作步骤1、鼠标点击时间,选择更改日期和时间设置,方法如下。2、在窗口中,选择internet时间,点击更改设置,方法如下。3、接着在窗口中,勾选与internet时间服...

2026-01-17 03:37 liuian

电脑如何进入bios模式(电脑怎么样进入bios)

电脑进入BIOS的方法1、按住F1电脑品牌:IBM、东芝、脸型thinkpad部分型号、toshiba等等这些型号电脑在开机时,按住键盘上的F1按键,那么它就会进入到BIOS的设置洁面中,需注意thi...

电脑如何设置虚拟内存(电脑怎么设虚拟内存怎么设最好)

进入系统打开控制面板后展开所有控制面板项,点击进入系统。修改虚拟内存点击高级系统设置后点击性能下的设置,点击高级后更改虚拟内存。设置数值将虚拟内存设置为自定义大小,具体数值最好是实际内存容量的一点五倍...

我的电脑图标打不开(电脑上图标消失了怎么恢复)

如果电脑点击图标没反应,首先看一下是不是鼠标左键的问题,左键出现故障图标往往是没有反应的,其次你把这些图标连一下,你看能不能画起来,如果无法划起来就是鼠标坏了,相反如果鼠标可以操作,但是电脑无法连接着...

联想y系列和r系列(联想7000)

联想y系列和r系列都好。其中r系列搭载的一般都是AMD锐龙处理器,y系列一般搭载的是英特尔处理器。希望我的回答对你有帮助一般情况下的话,联想笔记本电脑它的R系列和wy系列的画相比较来说是y系列,要稍微...

不激活win7有什么影响(不激活windows7会怎样)

如果Windows7未激活,会出现以下几种情况:1.桌面背景将变成黑色,每隔一段时间就会自动恢复成黑色。2.会弹出提示框,提醒用户需要激活Windows7。3.无法更新Windows,包括安...

超强升级系统 小说(超强升级系统 小说免费阅读)

女主柳洛溪,宋千千,肖甜甜,叶紫嫣,伏芸珊,南宫燕,菲菲,媛灵。狂暴系统的拥有者,龙家崛起的推动者,龙族守护者,天武大陆上屠魔者,新任远古界界王。前世为远古世界第一人,与远古世界一同孕育...

win11暂停更新点不了(win11设置永不更新)

win11更新不能暂停了是设置错误导致的,解决方法如下1、首先右键单击此电脑,选择管理。2、然后在中点击服务和应用程序。3、在弹出的列表中继续点击服务。4、在服务的右侧找到windowsupdate...

win10专业版下载速度慢(电脑win10下载速度慢)

由于是官方网址同时浏览该网址的网民非常多由于传输速率一定导致每个人的下载速率会变慢,可以错开高峰期如中午等,可以等到晚上或者早上期间进行下载。Win10系统浏览网页慢解决办法:1.在win10系统桌...

电脑关机总是关不掉(电脑关机一直关不掉怎么办)

电脑怎么关不了机是为什么电脑无法关机是因为还有软件在后台运行干预导致。鼠标右键点击计算机,选择属性,左侧菜单中选择高级系统设置,点击高级选项卡界面下方,启动和故障修复下的设置,取消勾选自动重新启动,点...

apple id是什么(appleID是什么意思)
apple id是什么(appleID是什么意思)

AppleID是苹果公司为其产品,如iWork、iTunesStore和AppleStore所引入的认证系统,使用Apple各项服务所需的用户名,就像是一把钥匙一样。有了AppleID,才能在苹果手机、平板电脑等设备上,使用苹...

2026-01-17 01:05 liuian

一键重装系统的软件有哪些(一键重装系统软件排行榜)

具体如下:一、韩博士装机大师韩博士装机大师是一款傻瓜式一键装系统工具,一键智能重装原版系统,无需光驱,无需U盘,零技术基础,傻瓜式操作,流水线流程,智能安装,完美支持GPT与win10平板!一款功能强...