Java程序内存分析:JMap与Eclipse Memory Analyzer - COD...

来源:百度文库 编辑:神马文学网 时间:2024/10/03 06:25:07
Java程序内存分析:JMap与Eclipse Memory Analyzer
当程序中内存使用过多,或者存在内存泄露时,经常会报OutOfMemory错误。很多时候,尤其是在生产环境中,不得不马上重启服务,导致现场丢失,无法查找问题所在。
其实jdk中自带了很多分析监控工具,jmap就是其中之一。
当程序出现问题,先不要停止服务,先用ps看一下java的pid, 然后运行命令将内存导出来:
[Copy to clipboard]View Code BASH
/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。