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文件:
是什么?
显示进程中任意一个线程某时刻的堆栈信息,对分析程序突然变慢有作用。
生成的原因?
生成 Heap Dump 的几种方式
core dump和heap dump的区别
认识Java Core和Heap Dump
故障排除指南