代码死锁,TPS低,RedisQPS低性能问题定位优化

问题:压测公司某业务线接口,TPS最大处理能力20左右,整个服务端资源无任何压力,cpu利用率较低6%,redis QPS较低

原因排查:出现此问题,根据经验一般是代码存在死锁导致,jstack查看堆栈信息和查看业务代码。根据业务功能是发表祝福时候会生成一个楼层数据,而生成楼层加了锁,以防止并发导致楼层重复。问题代码,部分涉及隐私,涂鸦,如图:



优化:由获取数据库id加锁改为redis自增获取。优化后,TPS由50提升到600,提升12倍,满足线上压力需求。


备注:查看堆栈信息方法可用本身自带命令 jstack -l pid >xxx.txt 方式导入文件进行分析,也可用jconsole、jvisualvm、jprofile,jprofile虽强大,但少用,jprofile占用整个服务cpu比较严重。


猜你喜欢

转载自blog.csdn.net/haoluojie/article/details/78763089