一次非必须参数为空导致的sql全表查询导致的内存溢出定位

最近项目中做了一个user-service服务的版本迭代,主要是做的登录接口回归压测,测试环境发现打的新包,刚重启系统,等一下就会出现OOM,后台日志出现

点击登录界面,无任何响应

通过LR压测,开启200个线程,大约5s左右,就会出现Java 堆内存消耗完

后台JVM分配的最大堆内存为512

在JVM的启动参数中添加

JVM_ARGS="-server -Xmx1024m -Xms1024m -Xmn256m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/home/deploy/projects/user-service/logs/qumf.dump -Dcom.sun.management.jmxremote.port=4501 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=192.168.10.45 -agentpath:/opt/jprofiler9/bin/linux-x64/libjprofilerti.so=port=4549,nowait"

出现OOM的时候,就会出打印dump日志

通过MAT分析

通过JProfiler定位

然后,叫开发定位代码,找到存在如下问题:

存在问题的java代码

sql查询引起的oom

有如下情况的service实现,在调用的时候需要判断需要查询字段是否为空,以避免加载全表数据到内存导致OOM

调用service:

 

service实现:

 

mapper配置文件:

 

解决后代码:

解决后的压测效果:

 至此,内存问题完美解决,压测监控jvm正常

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值