大家可能遇到这样的问题,mysql的主已经写入数据了,但是却没有同步到从myql那里,或者延迟很长时间才同步过去。说明一下我们的网络环境,我们每台数据库都有两个网线,分别连接内网和外网的千兆交换机,速度肯定不是问题。如果延迟很长的话,肯定是出问题,比如数据库被lock了,或者开发人员的一些不当的操作等。这时候就需要监控主从同步的状态已经主从同步的时间间隔等。以便及时与开发人员沟通,及时解决问题。下面是我自己写的一个脚本名字叫check_mysql_delay:
nagios中自己写的监控mysql主从复制的插件
原创
©著作权归作者所有:来自51CTO博客作者doctorwhere6的原创作品,请联系作者获取转载授权,否则将追究法律责任
#!/bin/bash
aa=`/usr/local/mysql/bin/mysql -u 用户 –p密码 --socket=/数据库目录/$1/mysql_$1.sock -e "show slave status\G"|egrep Read_Master_Log_Pos|awk '{print $2}'`
bb=`/usr/local/mysql/bin/mysql -u 用户 –p密码 --socket=/数据库目录/$1/mysql_$1.sock -e "show slave status\G"|egrep Exec_Master_Log_Pos|awk '{print $2}'`
cc=`expr $aa - $bb`
if [ $cc -gt 10000 ]
then
echo "$1 is CRITICAL $aa $bb $cc"
#exit $STATE_CRITICAL;
exit 2;
else
echo "$1 is OK $aa $bb $cc"
#exit $STATE_OK;
exit 0;
fi
把该脚本放到/usr/local/nagios/libexec目录下面。
然后修改/usr/local/nagios/etc/nrpe.cfg,在后面添加一行
command[check_mysql_delay3306]=/usr/local/nagios/libexec/check_mysql_delay 3306
注意这个3306就是给上面脚本当中$1赋值用的,如果有多个mysql实例的话,可以多写几行。
然后修改nagios服务器端的配置文件。在服务的配置文件中添加如下内容
define service {
use db-server
host_name host当中定义的主机名
service_description check_rep_delay3306
check_command check_nrpe!check_mysql_delay3306
}
然后重新加载一下nagios就ok了。
上一篇:2011,我的IT我的梦
下一篇:我的友情链接
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
mysql主从复制延迟监控 mysql主从复制速度
前言: 我们考虑到一些大型的数据库数据库读写分离对于大型系统或者访问量很高的互联网应用来说,是必不可少的一个重要功能。从数据库的角度来说,对于大多数应用来说,从集中到分布,最基本的一个需求不是数据存储的瓶颈,而是在于计算的瓶颈,即SQL查询的瓶颈,我们知道,正常情况下,Insert SQL就是几十个毫秒的时间内写入完成,而系统中的大
mysql主从复制延迟监控 mysql主从配置 mysql主从配置出现的问题 mycat读写分离 服务器