栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

JVisualVm处理OOM异常

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/599542.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号