一、线程dump
1、我最先使用的是线程dump,看线程是否有阻塞的,比如查看同步方法的;
2、线程dump是直接可以用editplus打开的,看起来很方便;
二、堆dump
1、速度比线程dump慢很多;
2、最近api经常会无故访问不了,进程是存在的,检查日志发现是因为堆内存溢出,其它接口虽然访问到了但是不能分配内存当然也就无法成功响应,然后僵死了导致服务不可用,在重启服务之前用jmap命令生成了一份dump文件便于后面分析。
生成dump文件的命令:
jmap -dump:format=b,file=20170307.dump 16048
3、生成dump文件后用java的jvisualvm打开。具体打开方式可参考我的另一篇文章:https://my.oschina.net/weiweiblog/blog/1787912
4、Java Heap Dump文件格式是一个HPROF二进制格式,需要特殊的工具才能进行分析,而这个文件通常都比较大,如果你的Heap Dump文件超过了几百MB,那就不要再寄希望于jhat了,因为jhat需要数倍于dump文件的内存。这个时候你可以用MAT(Memory Analyzer),用MAT你可以在有2GB可用内存的机器上分析大约1GB左右的Dump文件。