监控Mysql所在机器的CPU和磁盘IO

本文讲述了如何在Mysql出现too many threads running告警时,通过扩展lepus监控框架,结合定制脚本,同步获取主机及MySQL进程的CPU利用率、磁盘IO繁忙率和读写量,以便于分析问题原因,例如当thread running升高时发现磁盘IO能力不足导致性能下降。

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

背景:

Mysql服务器不时的会有too many thread running 的告警。有时候thread running 飙高时,各种查询和更新都慢,单条记录的commit都能超过5秒。
就想看看是为什么导致的,我们用的是lepus监控框架,能够监控到mysql内部的一些指标项。
但有时候需要了解mysq所在机器的信息,比如thread running飙高时的主机CPU和主机IO繁忙情况,以及此时此刻Mysql的CPU占用和IO繁忙情况。
这样对问题的发生就有比较全面的认识。

思路

因为我们用的是lepus监控框架,对mysql的指标监控是通过定时调用check_mysql.py来实现对mysql监控,check_mysql.py内部是这样实现的:

        ############################# CHECK MYSQL ####################################################
        mysql_variables = func.get_mysql_variables(cur)
        mysql_status = func.get_mysql_status(cur)       
        time.sleep(1)
        mysql_status_2 = func.get_mysql_status(cur)
        ......

func.get_mysql_status(cur) 其实就是调用show global status;

def get_mysql_status(cursor):
data=cursor.execute(‘show global status;’);
data_list=cursor.fetchall()
data_dict={}
for item in data_list:
data_dict[item[0]] = item[1]
return data_dict

通过两次show global status,获得1秒间隔内的各项指标差值,将这些差值记录下来,作为持续健康的记录,用于后续图形化的展示。
基于这个思路扩展,能否在定期获取mysql的各项指标时,同时获取主机的CPU和IO繁忙率,Mysql进程的CPU和IO繁忙率,以及主机所有进程的磁盘读写量和Mysql进程的磁盘读写量。和mysql的指标差值一起记录下来。后续在图表展示时,也能对照分析。达到类似这样的效果:
在这里插入图片描述
通过上面的图对比看,就知道数据库的thread running 飙高的根本原因是磁盘io能力不足。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值