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

  • Post author:
  • Post category:其他



问题:

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


原因排查:

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



优化:

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

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



版权声明:本文为haoluojie原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。