当程序中内存使用过多,或者存在内存泄露时,经常会报OutOfMemory错误。很多时候,尤其是在生产环境中,不得不马上重启服务,导致现场丢失,无法查找问题所在。

其实jdk中自带了很多分析监控工具,jmap就是其中之一。

当程序出现问题,先不要停止服务,先用ps看一下java的pid, 然后运行命令将内存导出来:

/usr/local/jdk1.6.0_20/bin/jmap -dump:format=b,file=/dir/heap.bin

这个heap.bin就是当前内存中的内容。如果很大,可以用gzip压缩一下。

此时就有很多工具来分析heap.bin了,我使用的是eclipse memory analyzer 。具体使用方法比较简单,里面可以看到每个对象的占用情况。

上两个我的程序出问题时的截图:

通过这两个图,很容易就定位出了Cache里的filter变量有问题。

我的实践中,改进之后,内存占用从1G下降到了60多M。