Zabbix监控mysql Master Slave主从同步(复制)状态,附脚本

php中文网
发布: 2016-06-07 16:35:08
原创
1567人浏览过

使用zabbix监控服务器的时候,用到了监控mysql的主从状态,有关mysql主从配置请看这篇文章:[备忘]mysql master slave主从同步(复制)配置及常见问题。 我们知道,Mysql主从复制同步(复制)启动后,要满足以下两个条件才算是成功,即: Slave_IO_Running:

使用zabbix监控服务器的时候,用到了监控mysql的主从状态,有关mysql主从配置请看这篇文章:[备忘]mysql master slave主从同步(复制)配置及常见问题。

我们知道,Mysql主从复制同步(复制)启动后,要满足以下两个条件才算是成功,即:

Slave_IO_Running: Yes
Slave_SQL_Running: Yes
登录后复制

脚本一

新建一个脚本文件,mysqlms.sh

#!/bin/bash
/usr/local/mysql/bin/mysql -uzabbix -e 'show slave status\G' |grep -E "Slave_IO_Running|Slave_SQL_Running"|awk '{print $2}'|grep -c Yes
登录后复制

将其放置到某目录(需要有权限),我这里放到/etc/zabbix/mysqlms.sh,在zabbix_agentd.conf中下方加入以下一条语句:

UserParameter=mysql.slavestatus,/etc/zabbix/mysqlms.sh
登录后复制

重启zabbix-agent:

sudo service zabbix-agent restart
登录后复制

截下来在Zabbix-Server所在服务器执行以下语句,测试是否成功:

Uni-CourseHelper
Uni-CourseHelper

私人AI助教,高效学习工具

Uni-CourseHelper 94
查看详情 Uni-CourseHelper
zabbix_get -s 192.168.1.106 -k  mysql.slavestatus
登录后复制

其中192.168.1.106为刚刚脚本所在服务器,mysql.slavestatus为Key值。若返回2,则表示主从服务正常。
然后将该监控项在web平台测加入items,设置好报警通知即可。
(如何加入ietms请查看这篇文章最下方:Zabbix服务器监控系统部署之自定义监控项的添加及配置(二))

脚本二

新建脚本mysqlms2.py

#!/usr/bin/python 
#coding:utf-8 
import MySQLdb 
import sys 
class check_mysql_repl(): 
    def __init__(self): 
        self.dbhost = 'localhost' 
        self.dbuser = 'root' 
        self.dbpass = 'wisp888' 
        self.dbport = 3306 
        self.sock = "/data/db_misc/mysql_3306.sock" 
        self.conn = MySQLdb.connect(unix_socket=self.sock) #根据实际情况连接
        self.cursor = self.conn.cursor(cursorclass = MySQLdb.cursors.DictCursor) 
        self.sql = 'show slave status' 
        self.cursor.execute(self.sql) 
        self.data = self.cursor.fetchall() 
        self.io = self.data[0]['Slave_IO_Running'] 
        self.sql = self.data[0]['Slave_SQL_Running'] 
        self.conn.close() 
    def get_io_status(self): 
        if self.io == 'Yes': 
            return 1 
        else: 
            return 0 
    def get_sql_status(self): 
        if self.io == 'Yes': 
            return 1 
        else: 
            return 0                
if __name__ == "__main__": 
    if len(sys.argv) != 2: 
        print "Usage: %s [io|sql]" % sys.argv[0] 
        sys.exit(1) 
    mysql = check_mysql_repl() 
    if sys.argv[1] == "io": 
        print mysql.get_io_status() 
    elif sys.argv[1] == "sql": 
        print mysql.get_sql_status()
登录后复制

(该脚本来自网络)
打开编辑文件

vi /etc/zabbix/zabbix_agentd.conf
登录后复制

下方加入以下内容:

UserParameter=mysql.repl_io,/etc/zabbix/mysqlms2.py io 
UserParameter=mysql.repl_sql,/etc/zabbix/mysqlms2.py sql
登录后复制

其他设置同脚本一。

完。

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号