一次内存溢出问题分析

问题描述

打开页面,页面卡死,后台报out of memory错误。

问题分析

1、查看jvm使用情况

命令:jmap -heap [pid]

发现堆内存的使用率已经达到了100%,总大小8g左右,并且一直不见下降。

2、生成dump文件

命令:jmap -dump:file=[] [pid]

最后生成的文件有7g大小.

将dump文件下载到本地,利用HeapAnalyzer软件进行分析。

3、利用HeapAnalyzer软件进行分析

但因为文件太大,HeapAnalyzer报内存溢出,无法打开。

4、使用eclipse插件分析

打开Eclipse - >help - > Eclipse Marketplace,搜索mat:

在这里插入图片描述

最大的对象有5G左

根据提示安装。

使用eclipse-File-Open File打开dump文件,依旧报错,无法打开。

5、在linux执行分析命令

下载工具:地址:http://www.eclipse.org/mat/downloads.php

如果下载失败,可以更换镜像来源重试

下载后将包传到linux服务器上解压。

在解压后的文件下执行命令:

./ParseHeapDump.sh 7.dump org.eclipse.mat.api:suspects org.eclipse.mat.api:overview org.eclipse.mat.api:top_components

7.dump为上一步生成的dump文件。

一开始同样报内存溢出的问题,解决方法是打开MemoryAnalyzer.ini文件,修改内存大小(我这里是直接改成了6G)。重新运行上述命令:

在dump文件目录下会生成3份.zip结尾的报告和一些m.相关的文件,将相关的文件都下载到windows本地磁盘。

6、分析结果

解压缩7_System_Overview.zip,打开index.html文件:

在这里插入图片描述

最大的对象有5G左右,推测可能是mybatis缓存的问题。

7、问题解决

打开mybatis配置文件,将poolPreparedStatements配置项由true改为false。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值