zabbix自定义监控mysql_如何用zabbix创建自定义监控项

背景:

zabbix本身提供了很多可选的监控项,可以满足绝大部分的监控需求。有时候由于业务需求,需要自定义监控项。 下面以创建mysql自定义监控项为例,分享如何创建zabbix自定义监控项。

环境说明:

zabbix版本:3.0.3 操作系统:CentOS 7 mysql版本:5.7.1

实现步骤:

1、修改 zabbix_agentd.conf,添加zabbix_agent 配置目录,以下是我本机的zabbix的配置: 将以下行的注释去掉

#Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf

变成:

Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf

将此行注释去掉后,zabbix_agentd启动后会自动扫描/usr/local/etc/zabbix_agentd.conf.d/目录下所有的.conf文件,并加载。

2、编写监控脚本/usr/local/zabbix/zabbix-script/get_mysql_status.sh,脚本如下(脚本存放目录可以自定义):

#!/bin/sh

case $3 in

uptime)

mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $2}'

;;

threads)

mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $4}'

;;

question)

mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $6}'

;;

sq)

mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $9}'

;;

open)

mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $11}'

;;

ftable)

mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $14}'

;;

opent)

mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $17}'

;;

qps)

mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $22}'

;;

*)

脚本说明,脚本需要输入三个参数分别是:mysql用户、mysql用户密码、mysql状态各项指标如下: uptime:运行时长单位s、 threads:开启的会话数、 question(questions):服务器启动以来客户的问题(查询)数目 sq(Slow queries): 慢查询数量 open(opens):服务器已经打开的数据库表的数量 ftable(Flush tables):服务器已经执行的flush ...、refresh和reload命令的数量 opent(open tables):通过命令是用的数据库的表的数量,以服务器启动开始 qps(Queries per second avg):select语句平均查询时间

3、在/usr/local/etc/zabbix_agentd.conf.d/目录下添加监控项配置文件get_mysql_status.conf,内容如下:

UserParameter=get_mysql_status[*],/usr/local/zabbix/zabbix-script/get_mysql_status.sh $1 $2 $3

4、重启zabbix_agent和zabbix_server,使用zabbix_get测试,如下:

#zabbix_get -s 127.0.0.1 -k get_mysql_status[root,weiming,open]

679

5、web端添加监控项: 在主机上添加监控项:

85f5e55f85774c4f14d568e2f3e33481.png

添加完成后可以看到新增监控项如下:

1c89ca20f1f12dde80141089dbc0c152.png

添加图形:

e1296de4f03f79704378c03416d3755b.png

图形预览:

e8f550682d269fc1db2ed7ab45cf0fa4.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Zabbix中配置自定义监控MySQL的Python脚本,需要进行以下步骤: 1. 创建Python脚本 首先,您需要创建一个Python脚本来连接MySQL数据库并执行查询。脚本应该返回所需的监控数据。以下是一个示例Python脚本的代码: ```python import pymysql # MySQL连接参数 mysql_host = 'localhost' mysql_port = 3306 mysql_user = 'user' mysql_password = 'password' mysql_db = 'database' # 连接MySQL数据库 conn = pymysql.connect(host=mysql_host, port=mysql_port, user=mysql_user, password=mysql_password, db=mysql_db) # 执行查询 cursor = conn.cursor() cursor.execute("SELECT COUNT(*) FROM my_table") result = cursor.fetchone()[0] # 返回结果 print(result) ``` 请注意,此脚本连接到本地MySQL服务器,并查询名为“my_table”的表的行数。您可以根据自己的需要修改此脚本。 2. 将脚本复制到Zabbix服务器 将脚本复制到Zabbix服务器的某个位置,例如“/usr/lib/zabbix/externalscripts”。确保脚本可执行,并且Zabbix用户具有对该文件的读取权限。 3. 在Zabbix中配置ALScripts 在Zabbix中,ALScripts是用于执行外部脚本的功能。要配置ALScripts,请执行以下操作: - 转到Zabbix Web界面中的“管理”>“通用配置”>“外部脚本”。 - 单击“创建脚本”按钮。 - 输入脚本名称,例如“mysql_monitor.py”。 - 在“脚本命令”字段中输入Python脚本的完整路径,例如“/usr/lib/zabbix/externalscripts/mysql_monitor.py”。 - 单击“保存”按钮。 4. 创建Zabbix监控项 现在,您可以创建Zabbix监控项来监视MySQL数据库。要创建监控项,请执行以下操作: - 转到Zabbix Web界面中的“配置”>“主机”。 - 找到要监视的MySQL主机,并单击其名称。 - 单击“创建监控项”按钮。 - 在“名称”字段中输入监控项名称,例如“MySQL行数”。 - 在“键”字段中输入以下内容:`ALScript["mysql_monitor.py"]`。 - 在“类型”字段中选择“Zabbix采集器”。 - 单击“添加”按钮。 现在,您已经成功地配置了一个自定义监控MySQL的Python脚本,并将其集成到Zabbix中。您可以在Zabbix中查看监控项的值,并设置警报以便在达到阈值时通知您。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值