【性能调优】堆外内存溢出

本文探讨了在项目上线后遇到的堆外内存溢出问题,推荐使用Jmeter进行性能测试,重点介绍了Jmeter的几个关键指标如HPS、TPS、QPS和吞吐量。在压测过程中发现,调用链路越长,性能影响越大。文章还提出了性能优化的六个方面,包括DB优化、模板渲染、静态资源处理、GC情况、业务优化和Redis缓存。针对堆外内存溢出,分析了SpringBoot中lettuce客户端的问题,并提供了升级客户端或切换到jedis的解决方案。

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

在工作中类似死循环的案例普通测试时测不出来的,一旦项目上线,会爆出很多雷,推荐使用Jmeter压测工具,它可以测出两种类型错误:内存泄露,并发与同步。
mac笔记本安装Jmeter:

brew install jmeter //事先安装homebrew才可使用此命令
open /usr/local/bin/jmeter  //打开JMeter

压测关注几个指标:
HPS:点击率
TPS:一个完整的业务流程,不同于数据库事务
QPS:Query Per Second 每秒查询率,每秒响应请求数
吞吐量:单位时间内处理请求的数量
响应时间

以下是测试www.baidu.com的接口情况,设置200个线程:处理请求最少6ms,最长371ms,吞吐量达到1520.9/s,性能确实不错。
在这里插入图片描述
压测项目接口列表如下:
在这里插入图片描述
由此推出:
单独网关服务,nginx,简单服务,吞吐量都很高,可是通过nginx代理到网关,然后网关路由到服务,吞吐量明显下降,可见调用链路越长,中间件越多,对性能影响越大。
性能优化从业务一般考虑如下几个方面:
1、DB(考虑sql加索引,sql优化)
2、模板渲染速度(thymeleaf线上要打开缓存,开发关闭)
3、静态资源(nginx动静分离)
4、visualvm查看GC情况,如果GC次数过多证明分配内存偏小
5、业务优化(优化掉频繁查库的操作)
6、加入redis缓存

在做到第6步的时候,发生堆外内存溢出

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值