最近项目中做了一个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代码
有如下情况的service实现,在调用的时候需要判断需要查询字段是否为空,以避免加载全表数据到内存导致OOM
调用service:
service实现:
mapper配置文件:
解决后代码:
解决后的压测效果:
至此,内存问题完美解决,压测监控jvm正常