如何分析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源,您可以在siginfoos::print_siginfo()方法中找到siginfo (操作系统进程信号信息), os::print_siginfo()Registers (CPU寄存器的值os::print_context() os_linux_x86.cpp方法等

我是否必须对此文件进行更改,以便这些工具可以解析它。

这是不可能的,因为Eclipse Memory Analyzer需要一个堆文件,HotSpot错误日志不需要。

这是一个文本文件。 在编辑器中打开它并尝试理解它的含义。