Java程序内存分析:JMap与Eclipse Memory Analyzer - COD...
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。
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请
点击举报。