Java堆转储Dump文件的几种方法

JDK附带了几种工具,可以以不同的方式捕获堆转储。所有这些工具都位于JDK文件夹下的主目录中。因此,只要这个目录包含在系统路径中,我们就可以从命令行启动它们。

Jmap

====

jmap是一种打印运行JVM内存统计信息的工具。我们可以将其用于本地或远程进程。

要使用jmap捕获堆转储,我们需要使用dump选项:

jmap-dump:[live],格式=b,file=

除了这个选项,我们还应该指定几个参数:

  • live:如果设置,则只打印具有活动引用的对象,并丢弃准备进行垃圾收集的对象。此参数是可选的

  • format=b:指定转储文件将采用二进制格式

  • file:将写入转储的文件

  • pid:Java进程的id

例如:

jmap -dump:live,format=b,file=/tmp/dump.hprof 12587

我们可以通过使用jps命令轻松获得Java进程的pid。

请记住,jmap是作为实验工具引入JDK中的,它不受支持。因此,在某些情况下,最好使用其他工具。

Jcmd

====

jcmd是一个非常完整的工具,它通过向JVM发送命令请求来工作。我们必须在运行Java进程的同一台机器上使用它。

它的许多命令之一是GC.heap_dump. 我们只需指定进程的pid和输出文件路径,就可以使用它获取堆转储:

jcmd GC.heap_dump

我们可以在执行之前使用相同的参数:

jcmd 12587 GC.heap_dump /tmp/dump.hprof

与jmap一样,生成的转储是二进制格式的。

JVisualVM

=========

JVisualVM是一个带有图形用户界面的工具,它允许我们监视、排除故障和分析Java应用程序。图形用户界面很简单,但非常直观,易于使用。

它的许多选项之一允许我们捕获堆转储。如果我们右键单击Java进程并选择“堆转储”选项,该工具将创建一个堆转储并在新选项卡中打开它:

Java堆转储Dump文件的几种方法

注意,我们可以在“基本信息”部分找到创建的文件的路径。

从jdk9开始,visualvm不包括在oracle jdk和open jdk发行版中。因此,如果我们使用java9或更新版本,我们可以从visualvm开源项目站点获得JVisualVM。

自动捕获堆转储

=======

我们在前面几节中展示的所有工具都是为了在特定时间手动捕获堆转储。在某些情况下,我们希望在java.lang.OutOfMemoryError因此它有助于我们调查错误。

对于这些情况,Java提供HeapDumpOnOutOfMemoryError命令行选项,当java.lang.OutOfMemoryError抛出:

java-XX:+HeapDumpOnOutOfMemoryError

默认情况下,它将转储存储在运行应用程序的目录下的java_pid.hprof文件中。如果要指定另一个文件或目录,可以在HeapDumpPath选项中进行设置:

java-XX:+HeapDumpOnOutOfMemoryError-XX:HeapDumpPath=

当应用程序使用此选项耗尽内存时,我们将能够在日志中看到创建的包含堆转储的文件:

java.lang.OutOfMemoryError: Requested array size exceeds VM limit

Dumping heap to java_pid12587.hprof …

Exception in thread “main” Heap dump file created [4744371 bytes in 0.029 secs]

java.lang.OutOfMemoryError: Requested array size exceeds VM limit

at com.baeldung.heapdump.App.main(App.java:7)

在上面的示例中,它被写入java_pid12587.hprof文件。

正如我们所看到的,这个选项非常有用,并且在使用这个选项运行应用程序时没有开销。因此,强烈建议始终使用此选项,特别是在生产中。

最后,还可以在运行时通过使用热点诊断MBean指定此选项。为此,我们可以使用JConsole并将heapdumpOnAutoFMMemoryError VM选项设置为true:

Java堆转储Dump文件的几种方法

JMX

===

本文将介绍的最后一种方法是使用JMX。我们将使用上一节中简要介绍的热点诊断MBean。此MBean提供接受2个参数的dumpHeap方法:

  • outputFile:转储文件的路径。该文件应具有hprof扩展名

  • live:如果设置为true,它只转储内存中的活动对象,正如我们以前在jmap中看到的那样

在下一节中,我们将展示两种不同的方法来调用此方法以捕获堆转储。

JConsole

========

使用热点诊断MBean的最简单方法是使用JConsole等JMX客户机。

如果我们打开JConsole并连接到一个正在运行的Java进程,我们可以导航到MBeans选项卡并在下面找到热点诊断com.sun.management 。在操作中,我们可以找到前面描述过的dumpHeap方法:

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值