线上jvm假死问题排查

1.线上告警接口超时

看接口是用户服务,查看nacos服务实例,发现有一个节点已经下线了

3.找到对应节点所在服务器,jps -l 命令发现用户服务还在,初步判断是假死

4.使用 jstat -gc 进程id 1000 每秒打印gc情况,发现频繁full gc,平均3秒一次,然后每次gc时间大概3~4秒

5.jmap -heap 进程id发现新生代和老年代都满了,紧急生成堆转储 jmap -dump:format=b,file=heapdump.hprof ,然后重启服务

6.使用MAT分析堆栈信息,排查内存泄漏的问题,看到分析是mysql查询时有占用了1.1G左右,jvm才配置了2G,当时想到可能是无条件查询导致查询了大量数据

7.继续排查看到线程的堆栈指向的业务代码是查询用户,看了下相关逻辑是有传手机号码查询用户的

8.由于是查询数据库占用了大量堆内存,所以判断当时查询肯定是很慢的,所以看了阿里云数据库的慢sql记录,果然发现查询返回了150多万数据

9.看了具体SQL是手机号码传1,使用的是模糊匹配,导致所有用户都查出来了

复制代码
select * from user where mobile LIKE '%1%'

10.调整代码为不使用模糊搜索,解决问题

复制代码
select * from user where mobile = '1'
相关推荐
康小庄7 小时前
AQS独占模式——资源获取和释放源码分析
java·开发语言·jvm·spring boot·spring·spring cloud·nio
码不停蹄的玄黓7 小时前
通关JUC:Java并发工具包从入门到精通 | 深度源码解析
java·jvm·spring boot·spring·spring cloud
YuTaoShao21 小时前
Java八股文——JVM「内存模型篇」
java·开发语言·jvm
张哈大1 天前
【 java 虚拟机知识 第二篇 】
java·开发语言·jvm·笔记
YuTaoShao1 天前
Java八股文——JVM「垃圾回收篇」
java·开发语言·jvm
@泽栖1 天前
讲讲JVM的垃圾回收机制
java·jvm·面试·八股文
ManageEngine卓豪1 天前
如何有效监控JVM环境,保障应用性能
jvm·虚拟机监控·应用性能监控·java 虚拟机
重庆小透明2 天前
【从零开始学习JVM | 第六篇】运行时数据区
java·jvm·后端·学习
gadiaola2 天前
【JVM面试篇】高频八股汇总——类加载和类加载器
java·jvm·面试
魔道不误砍柴功2 天前
《JVM 启动参数怎么写最优?从 Xms 到 GCLog 的调优实践》
jvm