记一次load飙升,频繁FullGC问题解决过程

本文详细记录了一次线上系统出现SQL连接异常、TPS正常但查询时间剧增的问题排查过程。通过分析发现,慢SQL、频繁GC及内存占用过高是主要原因。文章提供了具体的排查步骤,包括使用top命令查看资源情况、jstat命令监控GC状态、dump堆栈信息及使用JProfiler进行深入分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.现象

  • load飙升到30+
  • 线上sql连接异常
  • tps正常
  • sql查询时间剧增

在这里插入图片描述

2.解决过程

  1. sql连接池不够了,肯定是慢sql导致
  2. 频繁GC,一般内存使用过多
  3. 结合堆栈信息,某个对象内存占用特别多
  4. 某个sql查询数量大,调用量多,全表扫描。

3.GC查看

top 命令查看资源情况,找到使用率最高的线程
在这里插入图片描述
sudo -u spring-boot jstat -gcutil 384 200 50 命令查看内存使用,GC回收情况
在这里插入图片描述

4.dump堆栈信息

sudo -u spring-boot jmap -dump:format=b,file=heap.hprof 1375
在这里插入图片描述

5.下载文件

scp -r root@10.1.XX.XX:/tmp/hsperfdata_spring-boot/heap.hprof /Users/download
解释:root@ip:/目标文件地址 下载到那个文件地址

6.用JProfiler分析

注:图不是一次解决问题过程中截的,所以PID都不同

再一次生产 CPU 高负载排查实践

jstat命令查看jvm的GC情况

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值