如何分析JVM崩溃文件hs_err_pidXYZ.log
在Eclipse和Tomcat(wtp)中处理webapp时,tomcat崩溃并创建一个文件:hs_err_pid20216.log
我试图使用eclipse MAT来分析文件,但是MAT不能将文件识别为它可以处理的东西,我也尝试了DAT,它也是同样的事情。 它不会显示在打开的文件对话框中。
它是什么类型的文件?
我应该用什么来分析它?
我是否必须对此文件进行更改,以便这些工具可以对其进行解析。
日志文件可用作GitHub要点
更新:
有关如何处理hs_err_pidXYZ.log文件的更多信息,请参阅@Dan Cruz回复。 好奇的是,崩溃的原因是jackson被一个循环关系(双向一对多)弄糊涂了,但这是另一个故事……
它是什么类型的文件?
它是文本格式的HotSpot错误日志文件。
我应该用什么来分析它?
首先下载OpenJDK 6源包 。 在错误日志中搜索热点*.cpp
文件中的字符串。 查看源文件以获取错误日志包含的说明。
例如,使用OpenJDK 7源,您可以在siginfo
的os::print_siginfo()
方法中找到siginfo
(操作系统进程信号信息), os::print_siginfo()
的Registers
(CPU寄存器的值os::print_context()
os_linux_x86.cpp
方法等
我是否必须对此文件进行更改,以便这些工具可以解析它。
这是不可能的,因为Eclipse Memory Analyzer需要一个堆文件,HotSpot错误日志不需要。
这是一个文本文件。 在编辑器中打开它并尝试理解它的含义。