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<Long> idSet = items.stream().map(ItemVo::getId).collect(Collectors.toSet());
Map<Long, ResultVo> productMap;
try {
    productMap = detailMerchandiseService.getRichProductInfo(idSet, true, true);
    log.info(LogKit.mkEvent("qryPDC").p("params", idSet).p("productMap",productMap).end());
}

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值