每当发生oom异常,就生成dump文件,存储到某个目录下
-XX:+HeapDumponOutOfMemoryError -XX:HeapDumpPath=/apps/logs/tomcat出现OOM异常 喊运维下载dump文件
略
分析堆Dump文件(.hprof文件)将hprof文件装入 查看最占内存的东西
- 不要用jhat,jhat本身会创建一个web应用,通过访问localhost:7000可以看到堆信息,但是动不动就OOM,16G的笔记本完全无法通过jhat查看一个3G的hprof文件。
- 使用JvisualVm,它位于jdk的bin目录下,是jvm自带的内存可视化分析工具,idea开发者完全不用安装各种杂七杂八的软件,比如eclipse的memory analyzer,虽然它也很好用
概要也可以看出很多东西,但此次主要分析oom,所以直接看“类”,它会按内存消耗排列占用内存的东西
双击char[],跳转到下图,按大小从大到小排序,发现占用char最多的是qryPDC
Review代码代码如下,对照上图,可以看出是productMap过大,直接在一行日志里打出来,就把内存堆爆了,直接导致fullGC,所以删除这个日志,解决!
SetidSet = items.stream().map(ItemVo::getId).collect(Collectors.toSet()); Map productMap; try { productMap = detailMerchandiseService.getRichProductInfo(idSet, true, true); log.info(LogKit.mkEvent("qryPDC").p("params", idSet).p("productMap",productMap).end()); }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)