JVisualVm处理OOM异常

JVisualVm处理OOM异常,第1张

JVisualVm处理OOM异常 配置启动参数

每当发生oom异常,就生成dump文件,存储到某个目录下

-XX:+HeapDumponOutOfMemoryError -XX:HeapDumpPath=/apps/logs/tomcat
出现OOM异常

喊运维下载dump文件

分析堆Dump文件(.hprof文件)
  • 不要用jhat,jhat本身会创建一个web应用,通过访问localhost:7000可以看到堆信息,但是动不动就OOM,16G的笔记本完全无法通过jhat查看一个3G的hprof文件。
  • 使用JvisualVm,它位于jdk的bin目录下,是jvm自带的内存可视化分析工具,idea开发者完全不用安装各种杂七杂八的软件,比如eclipse的memory analyzer,虽然它也很好用
将hprof文件装入

查看最占内存的东西 

概要也可以看出很多东西,但此次主要分析oom,所以直接看“类”,它会按内存消耗排列占用内存的东西

 双击char[],跳转到下图,按大小从大到小排序,发现占用char最多的是qryPDC

Review代码

代码如下,对照上图,可以看出是productMap过大,直接在一行日志里打出来,就把内存堆爆了,直接导致fullGC,所以删除这个日志,解决!

Set idSet = 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());
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5607067.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-15
下一篇 2022-12-15

发表评论

登录后才能评论

评论列表(0条)

保存