shell监控MySQL主从状态脚本两则

内容为自己的一点总结,如有不对欢迎狠劲儿拍砖

本文来自http://yijiu.blog.51cto.com/转载请经博主同意,翻版可耻

监控主从复制正常与否

相比各位都应该知道,监控主从是否工作正常,涉及命令如下:

show slave status\G;

那么,我们需要关注的参数如下:

1. 首先查看SQL和IO线程是否为YES状态(想必各位都明白了)

2. 是否有延迟 是否大于0   #一般生成环境延迟是否大于500秒,如果大于500则报警,如大于1000则严重报警

#比如传递一个sql到slave上,binlog中在eventhear中存在time stamp时间戳,在下条binlog拿到的时间会进行比较,如果当前时间是多少则显示多少,如果更新非常频繁500秒会产生更多的sql积累在其中

至少生产中监控就是这么实现的以及包括nagios的监控插件也是这么实现的

主要关注的值本文来自http://yijiu.blog.51cto.com/转载请经博主同意,翻版可耻

1.
Master_Log_File 
Read_master_log_Pos
 
2.
Relay_Master_Log_File
Exec_Master_log_pos
 
3.
Seconds_Behind_master

判断一个库主要观察以上几点,如果主库挂了,Seconds_Behind_master 会已经成为NULL了

那么这样如何去观测从库是否日志同步完成,如下所示

通过shell实现监控同步的方法

废话不多说了直接上菜

1.利用status去观测是否已经同步完成

判断公式

以下为判断依据,判断以下值

Master_Log_File 和 Relay_Master_Log_File 的值必须相等

判断同步的偏移量

Read_master_log_Pos 和 Exec_Master_log_pos 的值必须相等

根据以上为最基础的判断依据,是否可将其从库提升为主库,就会在从库中判断master log file 是否读到的位置一样并找到一个最靠前的一个节点提升为主

shell内容如下所示:本文来自http://yijiu.blog.51cto.com/转载请经博主同意,翻版可耻

#!/bin/bash
user=‘root‘
password=‘mypass‘
thread_status=`/usr/local/mysql/bin/mysql -u"$user" -p"$password" -S /tmp/mysql_3308.sock -e ‘show slave status\G‘|grep -i yes|wc -l`
status=(`/usr/local/mysql/bin/mysql -u"$user" -p"$password" -S /tmp/mysql_3308.sock -e ‘show slave status\G‘| egrep -i "Master_Log_File|Relay_Master_Log_File|Read_master_log_Pos|Exec_Master_log_pos|Seconds_Behind_Master" |awk -F‘:‘ ‘{print $2}‘`)
echo ${status[4]}

if [[ "$thread_status" != 2 ]]; then
        echo "the Replication is Fault , at $(date)" > $catalog
        echo `uname -n` | mail [email protected] < $catalog
        exit 1
fi

if [[ "${status[4]}" > ‘300‘ ]];then
        echo "yan chi guo gao, at $(date)"  > $catalog
        echo `uname -n` | mail [email protected] < $catalog
        exit 2
fi

if [[ ${status[0]} == ${status[2]} ]] && [[ ${status[1]} == ${status[3]} ]]; then
        echo ‘The Replication is Normal‘
        exit 0  
  else
        echo "the Replication is Fault , at $(date)" > $catalog
        echo `uname -n` | mail [email protected] < $catalog
        exit 2
fi

本文来自http://yijiu.blog.51cto.com/转载请经博主同意,翻版可耻

2.依赖于程序检测 本文来自http://yijiu.blog.51cto.com/转载请经博主同意,翻版可耻

比如程序在master建立表,并随意设置字段,并在master上获取一个时间并写入

now的时间在程序中自行得到并记录,最后在slave中执行select 查看结果是否与时间对应一致

如果时间一样则认为正常,如果master上的时间减去slave上的时间 出现了延迟,那么证明延迟存在的,但是这种方法存在缺陷,比如主库挂了那么则不可用

#!/bin/bash
user=‘root‘
password=‘mypass‘
/usr/local/mysql/bin/mysql -u"$user" -p"$password" -e ‘replace into master.repl_heart set t=now(),id=1;‘ >/dev/null 2>&1

master_select=`/usr/local/mysql/bin/mysql -u"$user" -p"$password" -S /tmp/mysql.sock -e ‘select t from master.repl_heart where id=1;‘ | awk ‘{print $2}‘ | tail -1`
slave_select=`/usr/local/mysql/bin/mysql -u"$user" -p"$password" -S /tmp/mysql_3308.sock -e ‘select t from master.repl_heart where id=1;‘ | awk ‘{print $2}‘ | tail -1`

master_date=`date -d "$master_select" +%s`
slave_date=`date -d "$slave_select" +%s`
delay=`echo "$master_date"-"$slave_date" | bc`

if [[ $master_date == $slave_date  ]];then
	echo ‘is ok‘
   elif [[ $delay -le 500 ]];then
   	echo cun zai yan chi "$delay"
   else
        echo "the Replication delay too large "$delay" , at $(date)" > $catalog
	echo `uname -n` | mail [email protected] < $catalog
fi

需要注意的是:复制中,如果是行格式,就是主库的时间;如果不是行式,这个方法可以把now()这个内置函数在s脚本中生成再写入

以上,为监控mysql主从的两种shell的写法,如有不足,麻烦指出,感谢各位

时间: 2024-10-14 01:55:26

shell监控MySQL主从状态脚本两则的相关文章

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

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

使用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主从状态

首先上监控的脚本: #!/bin/bash status=`mysql -u root -p123 -e "show slave status\G" | egrep "Slave_IO_Running|Slave_SQL_Running" | awk -F: '{print $2}' | tr "\n" " "` arr_status=(`echo $status`) [[ ${arr_status[0]} =~ "

监控MySQL主从同步脚本

#!/bin/sh#date:2015-12-07#filename:Check_MySQL-rep.sh#作者:linuxzkq #Email:[email protected]#version:v1.0 Mysql_cmd="mysql -uroot -poldboy"Error_num=(1158 1159 1008 1007 1062) while truedo    rep=($($Mysql_cmd -e "show slave status\G;"|e

shell监控mysql主从同步

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

Shell开发MySQL主从监控脚本

监控MySQL主从同步是否异常,如果异常,则发送短信或者邮件给管理员. 1)开发一个守护进程脚本每30秒实现检测一次. 2)如果同步出现如下错误号(1158,1159,1008,1007,1062),则跳过错误. 阶段3:3)如果IO和SQL线程出现异常,则通知邮件给管理员 使用数组技术实现上述脚本(获取主从判断及错误号部分) 主从监控脚本如下: #!/bin/bash CODE=( 1158 1159 1008 1007 1062 2003 ) fun_Base(){ #1.定义变量 #1.1

监控mysql主从同步状态是否异常,如果异常,则发生短信或邮寄给管理员

阶段1:开发一个守护进程脚本每30秒实现检测一次. 阶段2:如果同步出现如下错误号(1158,1159,1008,1007,1062),请跳过错误 阶段3:请使用数组技术实现上述脚本(获取主从判断及错误号部分) [[email protected] ~]# mysql -u root -proot -e "show slave status\G;" *************************** 1. row ***************************       

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主从状态,并做邮件告警?

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