Mariadb cpu 93% 问题

最近项目遇到cpu平均使用率93%

一、登录数据库服务查看具体情况

可以看到服务器负载很高,,mariadb CPU使用已达到接近380.4% (因为是8核,所以会有超过100%的情况)。如下图:

二、排查是否有耗时较长sql

在服务器上执行mysql -u root -p之后,输入show full processlist; 可以看到正在执行的语句

登录数据库,我这里用的是dbeaver,执行show full processlist;

发现确实有条慢sql:select *from pump_event_his where msg_id='';

分析:这张表有500万+数据,且走全表扫描,要3.84s

通过EXPLAIN分析SQL语句

explain

select *from pump_event_his where msg_id='';

解决方法:给msg_id加个索引,再次查询后16ms

验证效果:

a.查询时间大幅度缩短(再次执行查询语句)

b.CPU负载很轻(执行top脚本)

三、如果排查不出问题,再看看下面的情况

1.查看磁盘空间

df -h

2.查看linux服务器查看CPU逻辑个数(查出来是8)

cat /proc/cpuinfo

cat /proc/cpuinfo | grep name | cut -f2 -d: | uniq -c

cat /proc/cpuinfo |grep "processor"|wc -l

2.1查看每个CPU核心数

cat /proc/cpuinfo |grep "cores"

3.查看cpu使用率,按照CPU使用率倒序

top

4.查看该进程下所有线程,按大写P按cpu排序

top -Hp 337499

5.具体到某个线/进程的stack信息

pstack 337499

6.跟踪某个pid的starce信息

strace -o output.txt -T -tt -e trace=all -p 337499

相关推荐
大猪宝宝学AI11 小时前
【AI Infra】SonicMoE论文笔记
论文阅读·人工智能·性能优化
DeepFlow 零侵扰全栈可观测12 小时前
3分钟定位OA系统GC瓶颈:DeepFlow全栈可观测平台实战解析
大数据·运维·人工智能·云原生·性能优化
RaidenLiu14 小时前
Offstage / Visibility:不可见真的就不消耗性能吗
前端·flutter·性能优化
论迹15 小时前
【多线程】-- JUC的常见类
java·开发语言·性能优化·多线程·juc
冻梨15 小时前
深入解析长列表性能优化方案
性能优化
卓码软件测评16 小时前
CMA/CNAS双资质软件测评机构【Apifox高效编写自动化测试用例的技巧和规范】
测试工具·ci/cd·性能优化·单元测试·测试用例
廋到被风吹走17 小时前
【Java】新特性最佳实践:避坑指南与性能优化
java·性能优化
爱可生开源社区18 小时前
MySQL 优化从库延迟的一些思路
数据库·mysql·性能优化
m0_5287238118 小时前
如何避免多次调用同一接口
前端·javascript·vue.js·性能优化
马优晨19 小时前
前端Network性能优化场景解析
性能优化·前端性能分析·谷歌浏览器network调试·谷歌浏览器network分析·浏览器性能调试