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 我们可以进行停止slave,跳过当前复制条数,进行下一条复制

[[email protected] script]# cat mysql_check.sh

#!/bin/bash

#

#2017.5.8

#mysql状态监测告警

. /etc/init.d/functions

Mysql_IO_cmd=`mysql -h 10.222.1.5 -uroot -p123456  -e ‘show slave status\G‘|grep Slave_IO_Running |awk ‘{print $NF}‘`

Mysql_SQL_cmd=`mysql -h 10.222.1.5 -uroot -p123456  -e ‘show slave status\G‘|grep Slave_SQL_Running |awk ‘{print $NF}‘`

Mysql_Be_cmd=`mysql -h 10.222.1.5 -uroot -p123456  -e ‘show slave status\G‘|grep Seconds_Behind_Master |awk ‘{print $NF}‘`

Mysql_Errno_cmd=`mysql -h 10.222.1.5 -uroot -p123456  -e ‘show slave status\G‘|grep Last_SQL_Errno |awk ‘{print $NF}‘`

ErrorNo=(1158 1159 1008 1007 1062)

##判断mysql复制的错误码

Mysql_Errno() {

for sum in $ErrorNo

do

if [ "$Mysql_Errno_cmd" == "$sum" ];then

echo "$(date +%F_%R)错误状态码:$Mysql_Errno_cmd" >> /tmp/mysql_error.log

mysql -h 10.222.1.5 -uroot -p123456  -e ‘stop slave;set global sql_slave_skip_counter=1;start slave;‘

echo `sort -r /tmp/mysql_error.log` |mail -s "MySQL Slave is error" [email protected]

else

echo "$(date +%F_%R)错误状态码:$Mysql_Errno_cmd" >> /tmp/mysql_error.log

#echo `sort -r /tmp/mysql_error.log` |mail -s "MySQL Slave is error" [email protected]

uniq  /tmp/mysql_error.log |mail -s "MySQL Slave is error" [email protected]

fi

done

}

##监测mysql状态函数

Mysql_status() {

if [ "$Mysql_IO_cmd" == "Yes" -a "$Mysql_SQL_cmd" == "Yes" -a "$Mysql_Errno_cmd" == "0" ];then

echo

action "mysql status" /bin/true

else

echo

action "mysql status" /bin/false

Mysql_Errno

fi

}

Mysql_status

时间: 2024-10-23 13:07:05

Mysql主从状态监控脚本的相关文章

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

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实战系列之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

MySQL 主从延迟监控脚本(pt-heartbeat)

对于MySQL数据库主从复制延迟的监控,我们可以借助percona的有力武器pt-heartbeat来实现.pt-heartbeat通过使用时间戳方式在主库上更新特定表,然后在从库上读取被更新的时间戳然后与本地系统时间对比来得出其延迟.本文主要是通过脚本来定期检查从库与主库复制的延迟度并发送邮件,供大家参考. 有关pt-heartbeat工具的安装可以参考:percona-toolkit的安装及简介    有关pt-heartbeat工具的介绍可以参考:使用pt-heartbeat监控主从复制延

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

使用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

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

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

一分钟教你快速建立起MySQL/Mariadb 主从状态检测脚本(shell)

脚本主要实现了网络检测和简单的主从状态检测,发现状态异常即发送邮件报警,在手机上安装一个易信可实现实时联动,及时获取服务器状态信息,脚本虽简单却实用. #!/bin/bash ##author:jerry_jiang mail_addr="[email protected]"br/>mail_addr2="[email protected]"ping 192.168.33.19 -c1 >/dev/nullsping1=echo $?ping 192.1

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

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