linux服务器cpu飙高问题排查实践记录

1 篇文章 0 订阅

问题描述:
测试环境大量请求出现504错误
1、第一反应上服务器看看资源消耗情况(登陆服务器时出现卡顿)
2、使用top命令查看cpu消耗情况,查看结果如下:
在这里插入图片描述
很明显cpu使用率已经满了(两核CPU)
3、使用ps -mp 23481 -o THREAD,tid,time | sort -rn命令获取线程信息,并找到占用CPU高的线程,信息如下:
在这里插入图片描述
4、使用命令printf “%x\n” 41846将将需要的线程ID转换为16进制格式

在这里插入图片描述
5、使用sudo jstack 23481 |grep “5c0d” -A 30命令打印线程的堆栈信息
在这里插入图片描述
通过代码很容易的分析出是因为最近项目加入了disruptor高效的消息队列

YieldingWaitStrategy是它的三种策略之一

com.lmax.disruptor.BlockingWaitStrategy
最低效的策略,但其对CPU的消耗最小,并且在各种部署环境中能提供更加一致的性能表现;

com.lmax.disruptor.SleepingWaitStrategy
性能表现和com.lmax.disruptor.BlockingWaitStrategy差不多,对CPU的消耗也类似,但其对生产者线程的影响最小,适合用于异步日志类似的场景;

com.lmax.disruptor.YieldingWaitStrategy
性能最好,适合用于低延迟的系统;在要求极高性能且事件处理线程数小于CPU逻辑核心树的场景中,推荐使用此策略;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值