20260416,日常开发-再记一次内存溢出

背景

本文清晰的记录一次线上卡顿的解决过程,1来作为记录,2来给其他人带来帮助。

现象描述

多位用户反馈,系统卡顿;

登录系统后验证,不分菜单进不去。偶现

时间线

|-------|------------------------------------|------------------------------------|-------------------------|
| 9:13 | 产品支持群,有人反馈系统慢 | | |
| 9:35 | 俊哥群里喊人,组内开发排查 | 主要是日志的error。大多集中在crpc超时、rabbitMQ异常 | |
| 10:19 | 长亮发现有OutOfMemoryError异常,决定重启32.9节点 | | 直接通过grafana看内存是否异常,可先重启 |
| 10:28 | 长亮重启完成,通知客户。且反馈正常 | | |
| 11:07 | 定位OOM代码位置,讨论后得知,大概率车型参数 | | |
| 11:21 | 长亮确认执行SQL,确实是车型参数为空。表568万 | t_detection_v2_picture_store | |
| 11:44 | 长亮修复代码并上线,10min后,上线完成 | | |

从单点反馈到开发介入:22分钟;

从开发介入到解决并确认:53分钟。

系统卡顿确认

确认系统和机器节点。

问题定位

📎java stack of catalina-exec-12.log

定位代码位置

复制代码
at com.chaboshi.web.qa.controllers.detectionPicture.DetectionV2PictureStoreController.edit() (line: 92)

问题最终确认

全表查询,500W+。

问题解决

经验总结

避免大表,全表查询。

日志检索

复制代码
appName:qa
callerIp:
class:com.rabbitmq.client.impl.ForgivingExceptionHandler
env:PRO
hostIp:172.21.32.9
hostName:172.21.32.9
level:ERROR
msg:An unexpected connection driver error occurred
pid:2897
spanId:
stackTrace:java.lang.OutOfMemoryError: Java heap space
thread:AMQP Connection 172.21.80.19:5672
timestamp:2026-04-16 09:10:32.693
traceId:
uriPath:

关键字:java.lang.OutOfMemoryError

相关推荐
布吉岛的石头1 小时前
线上服务凌晨OOM:一次因「无超时设置」引发的内存雪崩复盘
java
SamDeepThinking1 小时前
Spring Bean作用域的设计与使用
java·后端·面试
Flittly1 小时前
【SpringSecurity新手村系列】(2)整合 MyBatis 实现数据库认证
java·安全·spring·springboot·安全架构
Oliver_LaVine2 小时前
java项目启动报错:CreateProcess error=206, 文件名或扩展名太长
java·linux·jenkins
码农周2 小时前
告别大体积PDF!基于PDFBox的Java压缩工具
java·spring boot
devilnumber2 小时前
java中Redisson ,jedis,Lettuce和Spring Data Redis的四种深度对比和优缺点详解
java·redis·spring
摇滚侠2 小时前
Java 进阶教程,全面剖析 Java 多线程编程
java·开发语言
yaaakaaang2 小时前
十四、命令模式
java·命令模式
小锋java12343 小时前
【技术专题】Matplotlib3 Python 数据可视化 - Matplotlib3 绘制饼状图(Pie)
java