记一次JProfiler生产实战内存分析

背景

线上服务器4核cpu突然打满,通过top命令分析后,找到cpu最高的应用,是一个java应用。 找到java应用最高cpu的线程,这里有一个脚本可以直接找到。

cpu100.sh

发现是jvm线程,猜测应该是jvm垃圾回收导致。

调用

jstat -gcutil 1000

查看gc次数,发现full gc 2s一次,基本可以判断是垃圾回收内存导致。

dump下堆内存

jmap -dump:format=b,file=test.hprof

dump下来的文件通过JProfiler进行内存分析

分析过程

打开dump文件,如下 默认是按照实例数来排序的,从图上可以看出,基本是DeviceItemsRowData这个类太多导致。 找到对应的业务代码

点击DeviceItemsRowData,右键使用选定对象 选择传入引用 点击在图表中展示 点击+ 查看到线程号 点击线程转储,选中查询到的线程号 点击对应的线程号,找到相关的业务代码 进行代码分析 这个业务代码是根据选定时间去查询数据,可以判断是由于选取的时间段过长,返回数据量过多导致。

现在有个问题,能否查看到当时的访问参数?

根据堆栈信息找到controller入口, 可以看到是一个post请求,那我们只要获取到这个请求的入参对象即可,因为该方法没有结束,入参对象肯定是没有垃圾回收的,那就说明还在堆中,只要找到这个对象即可。 点击根据名称排序,找到该对象 右键->使用选中对象->传出引用 点击确认后,选中一个对象,即可查看参数 原来是查询了一年的数据,联系产品及开发,看看如何修复代码。

相关推荐
q***465214 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
Li_76953214 小时前
10分钟快速入手Spring Cloud Config
java·spring·spring cloud
源码技术栈14 小时前
Java基于云计算的社区门诊系统源码 医院门诊系统源码 已实现医保结算 SaaS模式
java·云计算·源码·诊所·门诊·预约挂号·云门诊
三七互娱后端团队14 小时前
告别“玄学”调参:DSPy 框架入门,让 AI 自动优化 AI 的提示词
人工智能·后端
星星电灯猴14 小时前
iPhone 抓包工具怎么选?从 HTTPS 调试、TCP 数据流分析到多工具协同的完整方案
后端
程序员西西14 小时前
SpringBoot整合JWT实现安全认证
java·计算机·程序员·编程
三七互娱后端团队14 小时前
别再只用 Vector Search 了:手把手教你落地 GraphRAG(图谱增强检索)
人工智能·后端
南雨北斗14 小时前
Kotlin中遍历集合的方法
后端
aiopencode14 小时前
Fiddler使用教程与抓包实战 HTTPHTTPS抓包、代理配置与接口调试完整指南
后端
星星电灯猴14 小时前
iOS 上架 H5 应用的可行性与实现路径,壳应用、合规要求与构建流程的技术分析
后端