认识Java Core和Heap Dump

什么是Java Core和Heap Dump

Java程序运行时,有时会产生Java CoreHeap Dump文件,它一般发生于Java程序遇到致命问题的情况下。

发生致命问题后,Java进程有时可以继续运行,但有时会挂掉。

为了能够保留Java应用发生致命错误前的运行状态,JVM在死掉前产生两个文件,分别为JavaCore及HeapDump文件。

JavaCore和Heap Dump的区别
  • JavaCore是关于CPU

JavaCore文件主要保存的是Java应用各线程在某一时刻的运行的位置,即JVM执行到哪一个类、哪一个方法、哪一个行上。它是一个文本文件,打开后可以看到每一个线程的执行栈,以stack trace的显示。通过对JavaCore文件的分析可以得到应用是否“卡”在某一点上,即在某一点运行的时间太长,例如数据库查询,长期得不到响应,最终导致系统崩溃等情况。

  • HeapDump文件是关于内存的。

HeapDump文件是一个二进制文件,它保存了某一时刻JVM堆中对象使用情况,这种文件需要相应的工具进行分析,如IBM Heap Analyzer这类工具。这类文件最重要的作用就是分析系统中是否存在内存溢出的情况。

如何生成Java Core、Heap Dump文件

这两个文件可以用手工的方式生成,当我们会遇到系统变慢或无响应的情况,这时就以采用手工的方式生成Java Core及Heap Dump文件。

在Unix/Linux上,IMB j9 JDK 1.8,产生这两个文件的方法如下:

# ps -ef | grep java  
user 4616 4582 0 17:30 pts/0 00:00:00 grep java  
root 5580 1 0 Oct27 ? 00:02:27 /usr/bin/java -server -XX:PermSize=64M -XX:MaxPermSize=128m -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file=/usr/local/tomcat8090/conf/logging.properties -Djava.endorsed.dirs=/usr/local/tomcat8090/endorsed -classpath :/usr/local/tomcat8090/bin/bootstrap.jar -Dcatalina.base=/usr/local/tomcat8090 -Dcatalina.home=/usr/local/tomcat8090 -Djava.io.tmpdir=/usr/local/tomcat8090/temp org.apache.catalina.startup.Bootstrap start  
# kill -3 5580

首先,找出Java进程id ,然后再执行‘kill -3 进程号’的操作,等文件生成后再做一次同样的操作,再产生一组文件。

通过ls 命令查看生成的文件:

javacore-dump-2020-10-10-14-26-12.0012.txt   //java core
dump-dump-2020-10-10-14-26-12.0007.phd     //Heap Dump

如何分析
1Java Core

IBM Thread and Monitor Dump Analyzer for Java

功能:IBM Thread and Monitor Dump Analyzer for Java是一个可以用来分析JavaCore日志中每个线程的信息并提供诊断信息的工具。

下载地址:https://www.ibm.com/developerworks/community/groups/service/html/communityview?communityUuid=2245aa39-fa5c-4475-b891-14c205f7333c

下载后可以获得名字类似jca457.jar的文件。jca是Java Coredump Analyzer的缩写,后面的数字是版本号。
使用方法:

jca***.jar是一个可执行的jar包。可以输入以下命令来运行。

<Java Runtime Environment path>java -jar jca457.jar

-jar是执行jar包的参数;

也可以使用·-Xmx·为执行jca457的进程分配最大堆内存。

<Java Runtime Environment path>java -Xmx500m -jar jca457.jar

打开软件后,通过File菜单选中生成的txt文件,即可打开:
在这里插入图片描述

2Heap Dump

IBM HeapAnalyzer
功能:一个用来寻找Java堆缺陷的图形化工具。

下载地址:https://www.ibm.com/developerworks/community/groups/service/html/communityview?communityUuid=4544bafe-c7a2-455f-9d43-eb866ea60091

下载后可以获得名字类似ha457.jar的文件。ha是Heap Analyzer的缩写,后面的数字是版本号。
使用方法:

jca***.jar是一个可执行的jar包。可以输入以下命令来运行。

-jar是执行jar包的参数;-Xmx用来为执行jca457的进程分配最大堆内存。

java –Xmx4g -jar ha456.jar

上面的代码为运行ha457的进程分配了4G的内存去运行。
注:由于发生HeapDump产生的文件往往比较大,进程在分析文件时需要占用大量内存。如果分配内存不够,有可能还没有分析完文件,程序就提示内存不够,从而中断分析。所以,必须保证你的机器的内存大小至少要大于Heap Dump文件。
注:由于发生HeapDump产生的文件往往比较大,进程在分析文件时需要占用大量内存。如果分配内存不够,有可能还没有分析完文件,程序就提示内存不够,从而中断分析。所以,必须保证你的机器的内存大小至少要大于Heap Dump文件。
在这里插入图片描述
【读者注】这个ha456.jar貌似废弃了,下载界面有个说明,建议使用Memory Analyzer Tool (MAT)
原文如下:

IBM HeapAnalyzer has no new development and therefore, in general, we recommend using the Eclipse Memory Analyzer Tool (MAT) with IBM DTFJ Extension instead which is open source and has active development, a similar feature set (finding large dominators, leak suspects, etc.), and the IBM Extensions for Memory Analyzer with product-specific analysis engines。

3.Memory Analyzer (MAT)

MAT工具是我个人补充的,原文没有介绍这种方式,功能非常强大,这个应该是现如今的主流工具了。
当然生成的内存转储文件就不仅仅是原文中的kill -3了,java map命令才是生成转储文件的首选方式。当然,如果你用的是ibm j9 的JDK,没有java map命令,只能用kill -3

下载地址 https://www.eclipse.org/mat/
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: javacore文件是Java虚拟机生成的一种文本文件,它记录了Java应用程序在运行过程中的线程堆栈信息、锁信息、内存使用情况等。它通常用于分析Java应用程序的性能问题和调试。 heapdump文件是Java虚拟机生成的一种二进制文件,它记录了Java应用程序在运行过程中的堆内存使用情况。它通常用于分析Java应用程序的内存泄漏和内存溢出问题。 ### 回答2: Javacore文件和Heapdump文件是两种不同类型的Java虚拟机(JVM)诊断文件。 Javacore文件是一种详细描述JVM线程状态和系统信息的文件。当JVM遇到致命错误或自然死亡时,它会自动创建Javacore文件。此文件列出了所有线程的状态,包括等待、运行和阻塞状态。还包括实时统计信息、堆栈跟踪和Java虚拟机配置信息等。这些信息对于诊断和修复JVM问题非常有用,例如内存泄漏、死锁、无响应等。 Heapdump文件是另一种JVM诊断文件,用于描述JVM的堆内存信息。当JVM内存达到一定限制或开发人员手动请求时,它会自动创建Heapdump文件。此文件包含了所有当前分配的对象和它们所占用的堆内存大小。它可用于分析内存泄露或内存占用量过高等问题。通过分析Heapdump文件,可以确定哪些对象占用了大量内存并进行相应的调整。 总体来说,JavacoreHeapdump文件都是非常有用的JVM诊断工具,可以用于分析和解决JVM问题。它们为开发人员提供了深入了解JVM运行时信息的机会,并帮助他们识别和消除潜在的性能问题。 ### 回答3: JavaCoreHeapDump文件是Java程序开发中常用的两种类型的文件。JavaCore是指Java进程在崩溃后生成的核心转储文件,而HeapDump则是指Java进程中的堆内存转储文件。这两种文件在程序调试和性能优化中都有重要的作用。 JavaCore文件是Java进程崩溃时生成的核心转储信息,可以用于分析崩溃的原因。JavaCore文件中包含了关于崩溃时程序的状态信息,如进程中活动的线程、线程的堆栈信息、内存的使用情况等。开发人员可以通过分析JavaCore文件来确定崩溃的根本原因,是由于代码错误还是由于内存溢出等问题。 HeapDump文件则是Java虚拟机在程序运行时生成的堆内存转储信息,用来分析Java程序的内存使用情况,可以帮助开发人员找出程序中的内存泄漏和对象的引用循环等问题。因为Java虚拟机的垃圾回收机制会自动回收不再使用的内存,所以开发人员需要及时分析HeapDump文件,找出那些占用大量内存且无法被回收的对象,以避免程序的内存溢出或内存泄漏等问题。 在实际开发中,JavaCoreHeapDump文件都扮演着非常重要的角色,可以帮助开发人员快速诊断和解决程序中出现的问题。因此,开发人员需要学会如何生成和分析这两种类型的文件,并及时修复程序中出现的问题,以提高程序的稳定性和性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值