生成java堆快照_你不得不知的6个JDK自带JVM调优工具

本文介绍了JDK自带的四个JVM调优工具:jinfo用于查看虚拟机配置信息,jmap用于生成堆快照和对象统计,jstack用于生成线程堆栈快照,jhat则用于分析jmap生成的dump文件。这些工具帮助开发者诊断Java应用的性能问题,如内存泄漏、线程死锁等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前面已经讲过了jps和jstat调优工具。今天我们继续说一下其他4个工具。这些工具都在jdk的bin目录下。

4ff9e5af9a98d588862db55f4bb417a5.png

如何使用jinfo工具

jinfo显示虚拟机配置信息,我们通过jinfo --help能看到相应的参数:

5295a5be275f0c36278fdf5e71a6e1e0.png

option说明

no option 输出全部的参数和系统属性-flag name 输出对应名称的参数-flag [+|-]name 开启或者关闭对应名称的参数-flag name=value 设定对应名称的参数-flags 输出全部的参数-sysprops 输出系统属性

我们可以先使用jps找到pid。

79585ab9a05d1cef464274fb2e89b81c.png

jinfo pid会输出一堆相关信息

c288a69fb7bc02823ec18c45d18f0c91.png

b5a652ef53824a7853d0f2b67c8962f1.png

jinfo -flags pid

用来输出JVM的全部参数

2dd158bc7848054452880d9c6959e688.png

jinfo -flag name pid

使用该命令,可以查看指定的name为 JVM参数的值。

如:查看当前 JVM进程是否开启打印·GC日志。

同样的可以使用

jinfo -flag [+|-]name pid

来开启或者关闭对应名称的参数 。

也可以使用

jinfo -sysprops pid

来输出当前 JVM进行的全部的系统属性

如何使用jmap工具

jmap(Java Memory Map) 命令,主要用于打印指定Java进程(或核心文件、远程调试服务器)的共享对象内存映射或堆内存细节。jmap以生成 java程序的 dump 文件, 也可以查看堆内对象示例的统计信息、查看ClassLoader 的信息以及 finalizer 队列。

jmap命令可以获得运行中的JVM的堆的快照,从而可以离线分析堆,以检查内存泄漏,检查一些严重影响性能的大对象的创建,检查系统中什么对象最多,各种对象所占内存的大小等等。可以使用jmap生成Heap Dump。

Memory = direct memory(直接内存) +JVM memory(MaxPermSize +Xmx);

jmap --help打印辅助信息

de75f40aac7ada0c851cbce13a640b9f.png

option说明

pid:java进程id,命令ps -ef | grep java获取,或者jps工具获取executable:产生核心dump的java可执行文件core:需要打印配置信息的核心文件remote-hostname-or-ip:远程调试的主机名或ipserver-id:可选的唯一id,如果相同的远程主机上运行了多台调试服务器,用此选项参数标识服务器-dump:[live,]format=b,file=使用hprof二进制形式,输出jvm的heap内容到文件=. live子选项是可选的,假如指定live选项,那么只输出活的对象到文件.-finalizerinfo 打印正等候回收的对象的信息.-heap 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况.-histo[:live]打印每个class的实例数目,内存占用,类全名信息. JVM的内部类名字开头会加上前缀”*”. 如果live子参数加上后,只统计活的对象数量.-clstats(取代了在JDK8之前打印类加载器信息的permstat)打印classload和jvm heap长久层的信息. 包含每个classloader的名字,活泼性,地址,父classloader和加载的class数量。

使用命名查看JVM的heap信息

jmap -heap pid

输出Java堆详细信息 ;

a30fde81410774c0e3bf3cefc82a1d7b.png

使用

jmap -histo:live pid

输出堆中对象的相关统计信息。

第一列是序号,第二列是对象个数,第三列是对象大小byte,第四列是class name

51acc52f4d9f71bd95523572b7aed50d.png

使用

jmap -finalizerinfo pid

输出等待终结的对象信息

c5e86bda882a24fc4ae1a605c86545c8.png

也可以使用

jmap -clstats pid

来输出类加载器信息 。

6f5bd60d900870958f286229bd92903a.png

如何使用jstack工具

jstack命令最大的作用就是用来生成thread dump文件,thread dump文件中记录了某一时刻CPU信息 。

jstack主要用于生成java虚拟机当前时刻的线程快照。线程快照是当前java虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等。线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做什么事情,或者等待什么资源。如果现在运行的java程序呈现hung的状态,jstack是非常有用的。

90cf67008dbe7ef829002bc61b1ba89d.png

option书面

-F:当正常输出的请求不被响应时,强制输出线程堆栈。

-l:除堆栈外,会打印出额外的锁信息,在发生死锁时可以用jstack -l pid来观察锁持有情况

-m:如果调用到本地方法的话,可以显示C/C++的堆栈

jstack pid

jstack命令会打印出所有的线程,包括用户自己启动的线程和JVM后台线程,我们主要关注的是用户线程;

24a7eb6ab7f164b9a992652ef6ec357e.png

1"http-nio-8080-exec-8" #26 daemon prio=5 os_prio=0 tid=0x000000005b940000 nid=0x1e2c waiting on condition [0x000000005c0be000] java.lang.Thread.State: WAITING (parking)

http-nio-8080-exec-8:线程名称daemon 表示线程是否是守护线程prio 表示我们为线程设置的优先级os_prio 表示的对应的操作系统线程的优先级,由于并不是所有的操作系统都支持线程优先级,所以可能会出现都置为0的情况tid 是java中为这个线程的idnid 是这个线程对应的操作系统本地线程id,每一个java线程都有一个对应的操作系统线程wait on condition表示当前线程处于等待状态,但是并没列出具体原因java.lang.Thread.StatC:\Users\Administrator\Desktop\ WAITING (parking) 也是表示的处于等待状态,括号中的内容说明了导致等待的原因,例如这里的parking说明是因为调用了 LockSupport.park方法导致等待

常用命令

497a6e6e97f4bb2bdcaf649383a5e579.png

如何使用jhat工具

JVM Heap Analysis Tool命令是与jmap搭配使用,用来分析jmap生成的dump,jhat内置了一个微型的HTTP/HTML服务器,生成dump的分析结果后,可以在浏览器中查看。在此要注意,一般不会直接在服务器上进行分析,因为jhat是一个耗时并且耗费硬件资源的过程,一般把服务器生成的dump文件复制到本地或其他机器上进行分析。

ddcdc7097f495f675f2888c0c1270047.png

运行,使用jps获取进程pid

bfadf79ec233cdb535bbe8317c2f99f8.png

再使用jmap -dump:format=b,file=heapDump pid

2af526acff44815b789b40875e5b2566.png

再到对应heapDump的包目录下执行

jhat heapDump

490051a7a10f4b3a6112376cf9ee225e.png

然后可以通过访问

http://localhost:7000/

941ca32684ea12ba64c40d90aba62031.png

一般查看堆异常情况主要看这个两个部分:

Show instance counts for all classes (excluding platform),平台外的所有对象信息。如下图:

a04b10c0e1160bf63200d61f075407da.png

Show heap histogram以树状图形式展示堆情况

6d5a8b4e4cf04bc186f5fa071d1108af.png

具体问题排查的时候,需要结合代码,然后观察是否大量应该被回收的对象在一直被引用或者是否有占用内存特别大的对象无法被回收。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值