Java程序突然死掉的原因一般有三种:

  • 程序OOM了,自己的Java程序申请内存创建对象的时候,申请的内存超出了堆内存的限制,此时我们叫做堆OOM了,当然还包括栈溢出,本地方法区溢出。
  • 程序占用的内存过大,被Linux的oom killer程序删除掉了,总的来讲就是,其他程序申请内存,但是发现内存不够了,Linux系统需要找到那个最耗费内存的程序(真实占用内存,非真实内存),然后把它kill掉。
  • Java程序出现了致命错误,或者JVM自己的bug,会产生一个hs_err_pidxxx.log文件。注意这里是指出现了一个错误,JVM都没有正常的处理这个这个错误,此时会生成这个文件,比如你下了1/0这种运行时错误,JVM已经捕获了这个错误,是不会有文件生成的。

Java core dump文件:普通JDK没有,IBM-JDK是由这个文件的。

Java dump/Heap dump文件:

是什么?

当JVM内存溢出的时候,产生该文件。.hprof结尾文件。JVM中的对象集合,对分析OOM很有用

如何生成?

JVM启动的时候配置XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=${目录},当发生内存溢出的时候就会产生该文件。或者使用命令

jmap -dump:live,format=b,file=d:\dump\heap.hprof < pid >

或者

jcmd < pid > GC.heap_dump d:\dump\heap.hprof

System core dump文件:

是什么?

中文常翻译为核心转储,系统级别的dump文件,相对于Heap dump,多了系统级别的一些信息。

生成的原因?

如果程序因为一些分段错误或其他原因崩溃,则会自动生成核心转储文件。如果通过control+c或者kill方法终止,则不会生成。运行kill -6可以强制生成该文件。(如果内存足够)大部分系统上都关闭了这个文件生成。

Thread dump文件:

是什么?

显示进程中任意一个线程某时刻的堆栈信息,对分析程序突然变慢有作用。