【outOfMemoryError】排查思路与解决方案
前言
不好啦❗ 天塌了❗ 系统崩了❗
快看啊,程序outOfMemoryError了🙈
我的心里活动:“哈哈哈😀哈哈哈😀终于给我碰上了,这个问题可很少发生啊,又积累一个问题。虽然我昨天发了版本,但是作为公司技术最好,长得最帅的我,代码肯定不出现这个问题。”
不想看废话的直接看【解决过程和方案】 吧
排查过程
theme: juejin
前言
不好啦❗ 天塌了❗ 系统崩了❗
快看啊,程序outOfMemoryError了🙈
我的心里活动:“哈哈哈😀哈哈哈😀终于给我碰上了,这个问题可很少发生啊,又积累一个问题。虽然我昨天发了版本,但是作为公司技术最好,长得最帅的我,代码肯定不出现这个问题。”
不想看废话的直接看【解决过程和方案】 吧
排查过程

首先肯定是先看日志,根据日志信息可以看到三个关键信息:
1. 业务代码中调用了远程接口
2. 内存溢出outOfMemoryError
3. Arrays.copyOf(Arrays.java:3332)
猜想❔
得到关键信息后,看了代码之后我就和技术经理做了一个简单的讨论
-
技术经理:调用远程接口没有设置超时时间,访问人数突然增多,导致请求阻塞。瞬间一万个请求进来,然后一个万的请求就阻塞了,从而导致内存溢出
-
我的猜想:请求之前没有查询大量的数据,就算请求阻塞也不会占用大量内存,导致
outOfMemory. 还有就是Tomcat的线程池也默认200,。就算一万个请求进来,同一时刻也最多处理200个请求,这个200个请求都阻塞的话会造成 系统卡死,但是不会出现outOfMemoryError呀虽然抛出了一个业务代码的错误,但是并不能肯定就是它引发的
outOfMemoryError,也可能是其他任务占了太多内存,这个请求只是一根“稻草”
解决过程和方案✔
-
修改启动命令,导出堆信息
定位outOfMemoryError还得用证据说话呀! 让技术经理在启动命令上加了如下参数-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./heapdump.hprof再次出现内存溢出就会将堆信息导出。 -
分析堆信息,定位大内存对象
因为之前已经装过分析dump文件的工具了,我用的是Intellij Profiler工具,打开堆快照文件如下:

根本问题已经浮出水面了,
KbResultSet、List<UnionCustomerCheckLog>这两个对象几乎把内存撑满了,jvm 堆内存最大1024M这两个就占了700M. 算是定位到问题了吧! 也推翻了技术经理说的调用远程接口大量请求被阻塞的问题。 -
查找GC回收日志
我们搜索自己的业务包名字就行了,这样就能很快定位关键问题。发现存在service 名称 和 上面大对象的名称一致UnionCustomerCheckLog同样的搜索方式在
summary栏目搜索,也能匹配上,并且定位到代码方法queryXXPassList()

-
定位问题代码 、分析代码
找到关键代码之后我们就看看代码吧:
select *? 这个写法是开发禁忌哦,加上这个sql的查询的结果有40W 条了。看看这个查询有啥用呢❓ 看看伪代码吧:
下面代码就是用代码实现的分组统计…没错就是我们
Android工程师写的,因为公司去年就不用维护客户端了,安卓写java,ios写前端。
刚好上午给老哥指出问题,下午就被人事约谈,领了大礼包了。// 查询出需要的所属数据:40w条 List<UnionCustomerCheckLog> xxPassList = unionCustomerCheckLogService.queryXXPassList();// 分组统计 Map<Integer, List<UnionCustomerCheckLog>> unionMap =xxPassList.stream().collect(Collectors.groupingBy(UnionCustomerCheckLog::getSource));for (DictModel dict : modelList) {ChartVo vo = new ChartVo();vo.setName(dict.getText());List<UnionCustomerCheckLog> checkLogList = unionMap.get(Integer.valueOf(dict.getValue()));if (Objects.isNull(checkLogList)) {vo.setNumber(0L);} else {// 统计长度vo.setNumber((long) checkLogList.size());}voList.add(pieChartVo); } -
解决问题
既然上面已经分析出问题所在了,就是Android老哥还不太会分组统计,就把数据全部查询到内存中统计。导致outOfMemoryError.
解决方法修改统计,改成SQL分组统计就行了:

程序逻辑也相应的调整就行了。
总结
由于工程师分组统计方式错误的实现,本来在数据库统计就行了,然而Android老哥却全部查询出来,然后再程序统计导致的内存溢出。
本篇文章分享了我去排查outOfMermoryError问题的过程,希望能帮到你,感谢一键三连🚀🚀🚀
有趣的是,上午定位到问题,并确认是
Android老哥写的,下午老哥就被约谈了,喜提大礼包。最近公司大裁员呀,已经裁了三分之一了,老哥们祝福我吧🧡🧡🧡
相关文章:
【outOfMemoryError】排查思路与解决方案
前言 不好啦❗ 天塌了❗ 系统崩了❗ 快看啊,程序outOfMemoryError了🙈 我的心里活动:“哈哈哈😀哈哈哈😀终于给我碰上了,这个问题可很少发生啊,又积累一个问题。虽然我昨天发了版本࿰…...
Python蓝桥杯刷题-小数第n位详解
题目描述 我们知道,整数做除法时,有时得到有限小数,有时得到无限循环小数。 如果我们把有限小数的末尾加上无限多个 0,它们就有了统一的形式。 本题的任务是:在上面的约定下,求整数除法小数点后的第 n 位开…...
Ubuntu服务器 /data 盘需要手动挂载的解决方案
服务器 /data 盘需要手动挂载的解决方案 如果重启服务器后,发现 /data 盘 没有自动挂载,通常是因为: /etc/fstab 配置文件 没有正确设置 自动挂载。该磁盘 没有被正确识别,需要手动挂载。文件系统错误 导致挂载失败。 下面是解…...
无法打开包括文件: “crtdbg.h”: No such file or directory
目录 无效解决措施(重装WindowsSDK) 有效解决措施 创建环境变量 添加环境变量INCLUDE 添加环境变量LIB RC无法运行 问题现象描述 复制以下文件至Error路径 无效解决措施(重装WindowsSDK) 参考文献:94176676/227706449-a5222d7d-d8d2-4a19-addb-8f546e69786f…...
番茄工作法html实现
对比了deepseek-r1-online和本地部署的14b的版本,输出的输出的html页面。 在线满血版的功能比较强大,可以一次完成所有要求。14b版本的功能有一些欠缺,但是基本功能也是写了出来了。 input write a html named Pomodoro-clock which “hel…...
多源 BFS 算法详解:从原理到实现,高效解决多源最短路问题
多源 BFS 是一种解决 边权为 1 的多源最短路问题 的高效算法。其核心思想是将所有源点视为一个“超级源点”,通过一次 BFS 遍历即可计算所有节点到最近源点的最短距离。以下从原理、实现和代码示例三个方面深入讲解: 目录 一、原理分析 1. 单源 BFS vs…...
使用IDEA提交SpringBoot项目到Gitee上
登录Gitee并新建仓库 创建本地仓库 提交本地代码到本地仓库 提交本地代码到远程仓库...
我们来学人工智能 -- DeepSeek客户端
DeepSeek客户端 题记使用后记系列文章 题记 我选择了 Cherry Studio是国内产品由CherryHQ团队开源是一个平台在这里,有豆包、kimi、通义千问的入口当然,最主要是作为大模型的UI正如标题,这里,作为DeepSeep的客户端 使用 下载本…...
【Linux】匿名管道的应用场景-----管道进程池
目录 一、池化技术 二、简易进程池的实现: Makefile task.h task.cpp Initchannel函数: 创建任务: 控制子进程: 子进程执行任务: 清理收尾: 三、全部代码: 前言: 对于管…...
JavaScript函数-函数的使用
在JavaScript编程中,函数不仅是组织代码的基本单元,也是实现复杂逻辑、提高代码复用性和可维护性的关键工具。无论你是刚开始学习JavaScript的新手,还是希望深入理解函数使用的开发者,本文都将为你提供全面的指导。 函数的基础知…...
水果生鲜农产品推荐系统 协同过滤余弦函数推荐水果生鲜农产品 Springboot Vue Element-UI前后端分离 代码+开发文档+视频教程
水果生鲜农产品推荐系统 协同过滤余弦函数推荐水果生鲜农产品 Springboot Vue Element-UI前后端分离 【亮点功能】 1.SpringbootVueElement-UIMysql前后端分离 2.Echarts图表统计数据, 直观展示数据情况 3.发表评论后,用户可以回复评论, 回复的评论可以被再次回复, …...
Android输入事件传递流程系统源码级解析
1. 硬件层到Linux内核 设备节点:触摸事件由内核驱动捕获,写入/dev/input/eventX。关键结构体:input_event(包含时间戳、类型、代码、值)。 2. Native层处理(system_server进程) 2.1 EventHub …...
自制操作系统学习第七天
今天要做什么? 实现HLT,不让计算机处于HALT(HLT).用C语言实现内存写入(错误,需要分析) 一:使用HLT,让计算机处于睡眠状态 写了下面这个程序,naskfunc.nas 函数名叫io_h…...
【多模态处理篇三】【DeepSeek语音合成:TTS音色克隆技术揭秘】
最近帮某明星工作室做AI语音助手时遇到魔幻需求——要求用5秒的咳嗽声克隆出完整音色!传统TTS系统直接翻车,生成的语音像得了重感冒的电音怪物。直到祭出DeepSeek的TTS音色克隆黑科技,才让AI语音从"机器朗读"进化到"声临其境"。今天我们就来扒开这个声音…...
Coze插件之基于IDE创建插件
上篇文章中,我们基于已有服务创建了一些插件和工具。方便我们开发更多工作流和智能体应用。 本篇文章要介绍的是基于IDE进行创建,为什么有了基于服务创建后还有基于IDE进行创建呢?基于IDE进行创建有哪些优势? 对于一些简单操作&…...
deepseek的模型经过训练 ai写出了linux 64位加壳软件
1. 加壳程序的设计目标 目标:保护64位Linux下的可执行文件,使其难以被反编译或调试。核心功能: 在运行时加载原始可执行文件并解密。隐藏壳代码和原程序的真正入口点。提供一定的反调试机制。 2. 思路 加壳流程: 加载器…...
解锁音频新境界:LALAL.AI 与 Audo Studio 深度解析
在音频处理的世界里,噪音常常是困扰我们的一大难题。无论是专业的音频工作者,还是普通的音频爱好者,都渴望拥有一款强大的工具来解决这个问题。今天,就为大家介绍两款来自 AI 工具导航(AIDH.NET)的 AI 语音…...
Kubernetes 使用 Kube-Prometheus 构建指标监控 +飞书告警
1 介绍 Prometheus Operator 为 Kubernetes 提供了对 Prometheus 机器相关监控组件的本地部署和管理方案,该项目的目的是为了简化和自动化基于 Prometheus 的监控栈配置,主要包括以下几个功能: Kubernetes 自定义资源:使用 Kube…...
20250221 NLP
1.向量和嵌入 https://zhuanlan.zhihu.com/p/634237861 encoder的输入就是向量,提前嵌入为向量 二.多模态文本嵌入向量过程 1.文本预处理 文本tokenizer之前需要预处理吗? 是的,文本tokenizer之前通常需要对文本进行预处理。预处理步骤可…...
【C++】const关键字的作用及常见应用场景
一、核心作用 用于定义“常量”,限制程序对变量的修改,提升代码安全性和可读性。其核心作用包括: 避免误修改:明确标识不可变数据。编译器优化:常量可被放入符号表,减少内存访问,优化执行效率…...
【网络安全-病毒】
网络安全-病毒 1.引导区病毒(Boot Sector Virus):感染硬盘引导扇区或软盘引导区,开机时先加载病毒,再加载系统,典型:小球病毒、大麻病毒,特点:早期 DOS 时代多࿰…...
Jimeng AI Studio实战:VLOOKUP函数在大数据处理中的应用
Jimeng AI Studio实战:VLOOKUP函数在大数据处理中的应用 1. 场景痛点:当Excel遇到大数据 做数据分析的朋友应该都深有体会:Excel里的VLOOKUP函数在小数据量时很好用,但一旦数据量大了,问题就来了。 我最近就遇到了这…...
从HMM到BiLSTM-CRF:我的NER模型进化之路与性能对比实验报告
从HMM到BiLSTM-CRF:我的NER模型进化之路与性能对比实验报告 三年前第一次接触命名实体识别(NER)任务时,我完全没想到这个看似简单的序列标注问题会让我在模型迭代的路上走这么远。从最初用HMM处理简单场景,到引入CRF解决标签依赖问题…...
MinIO 对象存储服务从零部署与使用指南
MinIO 对象存储服务从零部署与使用指南 在大数据、云原生、备份归档等场景中,对象存储 已成为基础设施的重要组成部分。MinIO 是一款高性能、兼容 S3 API 的开源对象存储系统,轻量且易于部署。本文将以 CentOS 7/8 为例,手把手带你完成 MinI…...
用MIPSsim模拟器调试alltest.asm:手把手教你观察CPU的‘内心戏’
用MIPSsim模拟器调试alltest.asm:手把手教你观察CPU的‘内心戏’ 当你第一次打开MIPSsim模拟器,载入alltest.asm样例程序时,是否感觉像面对一个黑箱?指令一条条执行,寄存器数值跳动着变化,但究竟发生了什么…...
自动驾驶训练中的图像增强技术解析与应用
1. 项目概述:自动驾驶训练中的图像增强技术在自动驾驶技术研发中,数据是模型训练的基石。但现实世界的数据采集往往受限于成本、天气和地理因素。2016年Waymo公开的报告中提到,他们的自动驾驶系统在测试阶段遇到暴雨天气时,识别准…...
测试左移右移之后:质量保障体系的未来形态
在过去的十年中,“测试左移”与“测试右移”已从行业热词演变为软件研发与质量保障领域的核心实践。左移将质量活动提前至需求与设计阶段,右移则将关注点延伸至生产环境与用户体验。这两大策略深刻重塑了测试工程师的角色与工作流。然而,当我…...
别再死记硬背了!用Wireshark抓包实战,5分钟搞懂PPP协议的CHAP和PAP认证区别
实战解密:用Wireshark透视PPP协议中CHAP与PAP的安全本质 当你第一次在路由器上配置PPP协议时,面对CHAP和PAP两种认证选项,是否曾困惑过它们真正的区别?教科书上那些"三次握手"、"两次握手"的理论描述…...
别再用Dijkstra处理负权边了!手把手教你用Bellman-Ford算法搞定带负权的最短路径问题
别再用Dijkstra处理负权边了!手把手教你用Bellman-Ford算法搞定带负权的最短路径问题 在算法竞赛和工程实践中,最短路径问题是最常见的图论挑战之一。许多开发者习惯性地使用Dijkstra算法解决所有最短路径问题,却忽视了负权边这一关键限制条件…...
为什么你的Loom项目上线后RT飙升300%?——基于3家金融客户真实故障根因分析
第一章:Loom项目RT飙升300%的典型现象与警示在某次Loom项目灰度发布后,监控系统突然捕获到关键API的平均响应时间(RT)从原先的120ms陡增至480ms,涨幅达300%。该异常并非偶发抖动,而是在持续15分钟内稳定维持…...
