python实战系列之MySQL主从状态监控(09)

1. 需求说明

由于openstack底层中MySQL使用了主从AB复制,为了监控数据库的主从状态信息,需要对MySQL的主从状态进行监控,从而保障数据库底层正常运行,为openstack提供更好的功能。本文对数据库执行监控,具体内容参考下面。

2. 程序内容

#!/usr/bin/env python
#_*_ coding:utf8 _*_
#author:happyliu
#用于监控MySQL主从复制状态

import os
import sys
import os.path
import urllib
import urllib2
import MySQLdb
import logging

auth_credentials = {‘host‘:‘localhost‘, ‘port‘:3306, ‘user‘:‘root‘,‘passwd‘:‘password‘}

‘‘‘
记录日志
‘‘‘
logging.basicConfig(
        filename = ‘/var/log/openstack_MySQL_replication_monitor.log‘,
        filemode = ‘a‘,
        format = ‘%(asctime)s %(filename)s[line:%(lineno)d] %(funcName)s %(levelname)s %(message)s‘,
        datefmt=‘%a, %d %b %Y %H:%M:%S‘,
        level = logging.INFO

)

def monitor_MySQL_replication():
        ‘‘‘
        用于监控MySQL主从复制状态,异常则告警
        ‘‘‘
        status = True

        try:
                conn = MySQLdb.connect(**auth_credentials)
                cursor = conn.cursor(cursorclass=MySQLdb.cursors.DictCursor)
                cursor.execute(‘SHOW SLAVE STATUS;‘)
                result = cursor.fetchone()
                if result[‘Slave_IO_Running‘] == "Yes" and result[‘Slave_SQL_Running‘] == "Yes":
                        logging.info(‘MySQL master/slave replication status is successfully‘)
                else:
                        logging.error(‘MySQL Master/Slave replication fail,Please check it‘)
                        status = False 
        except Exception as e:
                logging.error(e)
                status = False
        return status

def send_warnings(receiver,content,title):
        ‘‘‘
        发送RTX告警给业务负责人
        ‘‘‘
        rtx_url = "http://www.example.com:11770/sendRtxByPost"
        data = {
                "appId"         :6,
                "appKey"        :‘password‘,
                "userName"      :receiver,
                "title"         :title,
                "content"       :content
        }
        postdata = urllib.urlencode(data)
        req = urllib2.Request(rtx_url,postdata)
        return urllib2.urlopen(req)

def get_hostname():
        ‘‘‘
        获取Linux系统的主机名
        ‘‘‘
        return os.environ[‘HOSTNAME‘] 

def clean_log():
        ‘‘‘
        清理日志文件,当文件的大于100M时,则清理该文件,防止日志占用过多空间
        ‘‘‘
        log_file = ‘/var/log/openstack_MySQL_replication_monitor.log‘ 

        size = os.path.getsize(log_file) / (1024 * 1024)
        if size >= 100:
                os.remove(log_file)
                logging.info(‘%s have been remove‘ % (log_file))

if __name__ == "__main__":

        clean_log()
        warn_receiver = "happy;"
        if monitor_MySQL_replication():
                send_warnings(receiver=warn_receiver,content=‘云平台MySQL主从复制状态失败,请检查数据库状态‘,title=get_hostname())
时间: 2024-12-17 08:14:42

python实战系列之MySQL主从状态监控(09)的相关文章

Mysql主从状态监控脚本

目标:对Mysql从库进行状态监控,如果从库复制异常就告警 思路: 1.首先查找Mysql从库的4个参数值(show slave status根据这个命令):分别是从库的IO线程.SQL线程.复制延迟时间(这个在以下脚本没用到,可以再写个脚本对其延迟进行告警).错误码 2.函数Mysql_status判断,对IO线程.SQL线程.错误码三者逻辑与判断 3.如果为假则执行函数Mysql_Errno 4.对于mysql错误码为1158 1159 1008 1007 1062 我们可以进行停止slav

mysql主从状态监控脚本报警脚本

#!/bin/bash MYSQLPORT=`netstat -antlp |grep "LISTEN" ` |grep "3306" |awk -F[:""]+  '{print $4}' MYSQLIP = `ifconfig eth0` |grep "inet addr" |awk -F[:""]+ '{print $4}' STATUS = $(/usr/local/mysql/bin/mysql

zabbix自定义监控mysql主从状态,并做邮件告警

 通过zabbix自定义监控mysql主从状态,并做邮件告警 分析: mysql主要是通过主从来提供安全性,一个完整的主从体系,就应该包括数据同步.开启二进制日志.全备.还有对Slave_IO_Running和Slave_SQL_Running两个线程的实时监测,并做告警,而zabbix监控软件就提供了很好的方法:对于zabbix这个监控软件,个人来说也是比较熟悉,现在的企业们都基本用的是zabbix软件来做系统的资源的监控,zabbix的强大不仅仅体现于,它自身自带的监控模板比较全面,而是通过

利用Python监测MySQL主从状态

探测MySQL主从状态,如果从未同步,则发邮件通知运维人员.利用定时任务秒级监测! # -*- coding: utf-8 -* #! /usr/bin/env python from fabric.api import * from fabric.colors import * from fabric.context_managers import * from fabric.contrib.console import confirm import string import smtplib

使用zabbix监控mysql主从状态

公司mysql架构为一主多从.在日常使用过程中我们经常会遇到主从不同步的情况,为了及时处理此问题现使用zabbix监控mysql主从状态并设置触发器,如有异常则发送邮件报警. 我们都知道使用命令"show slave status \G"可以查看mysql从的状态,下面用脚本方式检查其状态. 在mysql-slave中进入zabbix-agent目录创建脚本文件. cat mysql_slave_status.sh #!/bin/bash /usr/local/mysql/bin/my

如何实时检测mysql主从状态,并做邮件告警?

实时检测mysql主从状态,并做邮件告警 需求分析: 当我们做完主从后,主从成功的话,Slave_IO_Running和Slave_SQL_Running两个进程的状态就为yes,但是在做主从同步时也不排除,会发生一些意外的情况,所以我们需要写个脚本来实时检测Slave_IO_Running和Slave_SQL_Running的状态,一旦mysql主从状态出现了状况,就通过邮件发送告警,然后再做维护. 脚本思路: 定时检测mysql主从状态,说白的了就是通过脚本让系统去自我检测主从状态,如果是主

window 平台下mysql主从的监控(window执行计划配合vb脚本)

(1)在window上安装ODBC(vb链接MySQL的驱动程序) 下载地址为:http://dev.mysql.com/downloads/connector/odbc/ 根据window系统选择相应版本即可. 我安装的是mysql-connector-odbc-5.3.4 如果在安装mysql-connector-odbc-5.3.4报错了, Error 1918.Error installing ODBC driver Mysql ODBC 5.3 ANSI Driver,ODBC err

mysql主从同步监控脚本

mysql主从同步监控脚本,利用mysql从库中的IO和SQL进程以及延迟时间来监控主从同步是否正常,详细shell脚本如下: #!/bin/bash #author wangning #date 2017-7-17 #qq 1198143315 #Email [email protected] ################################## define variable############################# define_variable(){ ip

Python 实战系列-微信或网页远程控制电脑

本系列课程为Python实战系列课程:使用微信控制电脑,使用Python的Web框架Flask搭建网页,并使用网页控制电脑:使用wxPython编写图形化的程序,并进一步将这个程序发展为远程控制程序. 课程目录: |--|----|----1 微信远控:Python 控制电脑的两种方法|--|----|----|----1 课程介绍.mp4|--|----|----|----2 命令提示符 CMD 入门.mp4|--|----|----|----3 Python 执行 CMD 命令.mp4|--