zabbix 监控Mysql

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介:

Zabbix 采集mysql的方法有很多,常用的是通过pythonshell执行show status 或者show global status 获取值

二者的区别:

Show status;是当前的会话,你查看到的很多参数都是为0

Show global status;是你全局的会话,你重启数据库或者关闭都会失效

所以,再采集数据的时候,以global status 为主

简单的脚本如下(只采集Com_select,delete,update,rollback为列)

#!/usr/bin/env python

import os

def mysql_info(Source,socket,Items):

        User,Password,port = Source

        mysqladmin=os.popen('which mysqladmin').read().strip()

        comm='%s  -u%s -p%s -P%s -S%s  extended-status | grep -w "%s"|cut -d "|" -f 3' \

        %(mysqladmin,User,Password,port,socket,Items)

        Value=float(os.popen(comm).read().strip())

        print Value

if __name__ == '__main__':

        item = sys.argv[1]

        Source=['root','ema',3306]

        socket="/var/mysql/data/mysql.sock"

        mysql_info(Source,socket,item)

这个只是一个简单的脚本,还有很多优化和调整的地方

执行结果:

[root@DB-Server ~]# python test.py Com_select

Warning: Using a password on the command line interface can be insecure.

3714689.0

Ok,把我们的脚本加入到zabbixUserParameter.conf配置文件中

UserParameter=mysql_info[*],/usr/bin/python /usr/local/zabbix/script/test.py $1 

重启zabbix_agentd

zabbix_server上,通过zabbix_get 调试看看是否可以获取到这个值

zabbix_get -s 10.132.63.37 -p 10050 -k 'mysql_info[,Com_select]'               

3714889.0

OK,现在是可以获取到这个值,接下来就是去创建items

wKioL1Sb0JejafqiAAKa3_p_BtI811.jpg

 

graph 动态显示数据

wKiom1Sbz-ryEFPnAAMXJBO126E598.jpg

 

会发现有很多0.000??多少的qps,这个数据是怎么来的呢

去查看了下zabbixhistory的表

SQL 语句(没有优化):

select itemid,from_unixtime(clock,'%Y%m%d %H:%i:%S') ,value from history where itemid=27077 and from_unixtime(clock,'%Y%m%d %H:%i:%S') > "20141225 14:00:00";

|  27077 | 20141225 16:27:17 | 0.4531 |

|  27077 | 20141225 16:28:17 | 0.7770 |

|  27077 | 20141225 16:29:17 | 0.5366 |

|  27077 | 20141225 16:30:17 | 5.7420 |

|  27077 | 20141225 16:31:17 | 2.4279 |

|  27077 | 20141225 16:32:17 | 0.4173 |

|  27077 | 20141225 16:35:17 | 0.6591 |

|  27077 | 20141225 16:36:17 | 0.3716 |

|  27077 | 20141225 16:37:17 | 0.4951 |

|  27077 | 20141225 16:38:17 | 0.3676 |

|  27077 | 20141225 16:39:17 | 0.41

94 |

|  27077 | 20141225 16:40:17 | 0.3968 |

|  27077 | 20141225 16:41:17 | 0.3667

每分钟都是去采集一次,但怎么计算的呢

我比较笨的方法就是在server上通过zabbix_get获取值,再除去采集的时间,发现数据大致类似

所以,总结如下:这个值的计算是通过两次计算采集到数据的差值(zabbix_get 间隔1分钟去采集数据),再除去你的间隔时间就是每秒的qps

所以,假设你采集数据的间隔为1分钟,如果你采集到的值在这一分钟内没有超过60,就会是1以下的数据

 

以上是个人监控MYSQL时的简单记录,如果有错误的地方,还请指出!




      本文转自天真花语  51CTO博客,原文链接:http://blog.51cto.com/caibird/1596001,如需转载请自行联系原作者





相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
21天前
|
监控 关系型数据库 MySQL
《MySQL 简易速速上手小册》第7章:MySQL监控和日志分析(2024 最新版)
《MySQL 简易速速上手小册》第7章:MySQL监控和日志分析(2024 最新版)
39 3
|
1月前
|
存储 监控 关系型数据库
轻松入门Mysql:MySQL性能优化与监控,解锁进销存系统的潜力(23)
轻松入门Mysql:MySQL性能优化与监控,解锁进销存系统的潜力(23)
|
2月前
|
SQL 监控 关系型数据库
MySQL性能调优:监控和优化
MySQL性能调优:监控和优化
65 1
|
3月前
|
监控 关系型数据库 MySQL
HeartBeat监控Mysql状态
HeartBeat监控Mysql状态
|
4天前
|
Prometheus 监控 Cloud Native
使用mysqld_exporter监控所有MySQL实例
使用mysqld_exporter监控所有MySQL实例
33 2
|
1月前
|
监控 网络协议 Unix
centos7 zabbix安装客户端agent -配置监控远程主机 在需要监控的电脑上安装
centos7 zabbix安装客户端agent -配置监控远程主机 在需要监控的电脑上安装
22 0
|
1月前
|
监控 关系型数据库 MySQL
zabbix 监控mysql服务
zabbix 监控mysql服务
17 0
zabbix 监控mysql服务
|
2月前
|
数据采集 监控 数据库
请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
【2月更文挑战第25天】请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
26 2
|
4月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
5月前
|
数据采集 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
85 4

推荐镜像

更多