mysql-slave-check监控

本文介绍了一个Python脚本,用于检查MySQL从库的状态,包括读取从库的运行状态,并通过执行特定的SQL命令来判断从库是否正常工作。此脚本适用于基于Nagios或类似监控系统的自动化监控。

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

#mysql-slave-check
UserParameter=mysql-slave175,python /home/admin/sbin/cmd.py mysql-slave xx.xx.xx.xx 3306 xxxxxxx

 

$ cat /home/admin/sbin/cmd.py
#!/bin/env python
#coding:utf-8

import os,sys,json,commands,socket,time

def service_check_cmd(name,ip,port,pwd):
        global status
        if name == 'redis':
                codisCmd="/opt/redis/src/redis-cli -c -h %s -p %s set service_check ping" % (ip,port)
                try:
                    status=commands.getoutput(codisCmd)
                    if status == 'OK':
                        return 0
                    else:
                        return 1
                except:
                    return 1
        
        elif name == 'mysql-slave':
                slaveCmd="/opt/mysql/bin/mysql  -udba -p%s  -h%s  -e 'show slave status\G' | grep -E 'Slave_IO_Running'\|'Slave_SQL_Running' | grep -v 'Slave_SQL_Running_State' | awk '{print $2}' | grep Yes | wc -l"  % (pwd,ip)
                slavestop="/opt/mysql/bin/mysql  -udba -p%s  -h%s  -e 'start slave;'" % (pwd,ip) 


                try:
                    status=commands.getoutput(slaveCmd).split('\n')[1]
                    if int(status) == 2:
                        return 0
                    elif int(status) != 2:

                        return 1
                except:
                    return 1

print service_check_cmd(sys.argv[1],sys.argv[2],sys.argv[3],sys.argv[4])
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值