rammap

windows server 2008 环境下,运行java程序,内存耗尽问题

独自空忆成欢 提交于 2021-02-13 20:49:15
经历的几天的分析,希望把自己学到的知识总结一下。 系统版本:Windows Server 2008 R2 Standard 系统类型:64bit 内存:32GB 程序:在系统上部署了solr,然后写5个线程不停的向solr查询。 问题现象:任务管理器中物理内存一直增长,最后到了99%。但是进程占用的内存加起来不到10G。 分析: 第一步:怀疑java程序内存溢出。 工具: jvisualvm与eclipse mat jvisualvm检测是否内存溢出,如果存在内存溢出,可以用用jmap导出dump文件,再用mat分析。mat可以分析到每个类占用的内存。网上有很多mat的使用资料,大家可以自己查询。 我使用了jdk自带的jvisualvm,在jdk bin目录下jvisualvm.exe检测内存。如下图: 通过上图,发现heap会收集的,所以不存在内存溢出。为了熟悉,jmap,mat工具,我自己导出dump文件,用mat也分析了一下。 第二步:进一步分析 如果程序没有内存溢出问题,那么内存被什么占用了呢? 分析工具: RamMap与VMMap RamMap 可以整体分析内存使用情况,VMMap可以精确到某个进程ID,他们都可以查看什么文件已经从磁盘映射到内存。 我用RAMMAP分析,发现大量的内存被Mapped File占用,点击Empty--Empty Working Sets