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

背景:

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能力不足。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值