当前位置:网站首页>记一次生产内存溢出分析解决
记一次生产内存溢出分析解决
2022-08-08 08:36:00 【南城.南城】
情景
一个怡然自得的下午,正开心的mo着鱼,突然测试发来一条消息,说现网功能出问题了。
我慌忙的开始排查问题,打开日志一看
java.lang.OutOfMemoryError: GC overhead limit exceeded
GC回收不到内存,内存溢出了
虽然说这种情况重启服务就能暂时解决,但是如果不找出根源问题,修改代码。那么即使重启了,也还会再次出现。
解决过程
简单的看了一下报错出错的类的逻辑,分析之后觉得应该不是这个类的问题。既没有循环,也没有大量的new实例,也没有用到list等集合、数组。
那么应该就是别的地方使用了大量的内存,导致这里运行时获取不到内存,GC也回收不到内存然后报的错。
然后上网查询了一下,很多方案都是说分析内存溢出快照。但是这玩意得在项目启动时添加启动参数才会在内存溢出时自动生成,-XX:+HeapDumpOnOutOfMemoryError
-Xms21m -Xmx21m -XX:+HeapDumpOnOutOfMemoryError
不过还好生产的项目启动时加了,因为我搜索到了内存溢出的快照文件
可以看到内存溢出文件名的pid就是我们进程的pid,说明这个内存溢出快照文件就是我们想要的
下载内存分析工具JPROFILER(工具是收费的,不过刚安装的前10天是免费的。10天应该够用了吧,不能项目天天内存溢出吧,那代码问题也太大了)
可以看到pdf的是实例对象有两个1000多万个,查看代码后发现是pdf中表格的行对象(一个定时生成pdf发送邮件的任务),就是说生成的这个pdf表格有1000多万行。这明显是不合理的,分析过后发现按照需求统计确实会出现这么多数据,这么多数据的pdf报告客户根本是看不了的。因此需要重新规划需求,或是限制查询出的行数。
最后和产品确认之后限制了sql查询出来的数据条数,解决了此次问题。
边栏推荐
- Want to use SQL to achieve two days after the data contrast, the new data sheet and a list of tags
- 数学基础(一)矩阵对角化、SVD分解以及应用
- 【vulhub】PostGresql高权限命令执行漏洞复现(CVE-2019-9193)
- ACWing 198. Antiprime Problem Solution
- 1252_FreeRTOS_堆栈溢出检查方法与测试
- 数据智能正当时,九章云极DataCanvas公司荣获“最具投资价值公司”
- lua --- 基本语法学习
- Data Governance (3): Data Quality Management
- 数学基础(二)逆矩阵、伪逆矩阵、最小二乘解、最小范数解
- LabVIEW前面板和程序框图的最大尺寸
猜你喜欢

【优化调度】基于粒子群实现并网模型下微电网的经济调度优化附matlab代码

攻防世界——ics-05

Literature Learning (part33)--Clustering by fast search and find of density peaks

matlab simulink串级变比值模糊PID烟气脱硫浆液pH值控制

DVWA全级别详细通关教程

22-08-06 西安 EasyExcel实现字典表导入、导出

DVWA full level detailed customs clearance tutorial

你一定要看的安装及卸载测试用例的步骤及方法总结

双馈风电机组备用容量控制策略研究

My MySQL installation that is how to solve
随机推荐
[Deep Learning] Curriculum Learning
【vulhub】PostGresql高权限命令执行漏洞复现(CVE-2019-9193)
volatile在C语言中的基本使用方法
spark2 sql struct处理
matlab simulink串级变比值模糊PID烟气脱硫浆液pH值控制
VSCode代码格式化快捷键及保存时自动格式化
Implementation principle of priority queue
Nacos是如何实现心跳机制和服务续约以及超时剔除服务机制的?
【Enumeration】Continuous factor
[Raspberry Pi] vim editor
under项目under项目
图数据科学和机器学习图数据科学GDS概览
lua --- 基本语法学习
Offensive and defensive world - ics-05
Defense - MFW all over the world
[Regression prediction] Gaussian process regression based on GPML toolbox with matlab code
简单理解MVVM模型
jupyter lab安装、配置教程
炽热如初 向新而生|ISC2022 HackingClub白帽峰会圆满举办
Go 函数与方法