监控Mysql主从同步

1.shell监控主从同步

编写一shell脚本,监控slave的两个yes(Slave_IO及Slave_SQL进程),如发现只有一个或零个yes,就表明主从有问题了

___________________________________________________________

vim /sh/mysql_slave.sh
#!/bin/bash
#check MySQL_Slave Status
#crontab time 00:10
MYSQLPORT=`netstat -na|grep "LISTEN"|grep "3306"|awk -F[:" "]+ '{print $4}'`
MYSQLIP=`ifconfig eth0|grep "inet addr" | awk -F[:" "]+ '{print $4}'`
STATUS=$(/usr/local/mysql/bin/mysql -u szk5043 -pszk5043 -S /tmp/mysql.sock -e "show slave status\G" | grep -i "running")
IO_env=`echo $STATUS | grep IO | awk ' {print $2}'`
SQL_env=`echo $STATUS | grep SQL | awk '{print $2}'`
if [ "$MYSQLPORT" == "3306" ]
      then
   echo "mysql is running"
      else
   mail -s "warn!server: $MYSQLIP mysql is down" szk5043@foxmail.com
fi
if [ "$IO_env" = "Yes" -a "$SQL_env" = "Yes" ]
      then
   echo "Slave is running!"
      else
   echo "####### $date #########">> /tmp/check_mysql_slave.log
   echo "Slave is not running!" >> /tmp/check_mysql_slave.log
   mail -s "warn! $MySQLIP_replicate_error" szk5043@foxmail.com
fi
建议每十分钟运行一次。
*/10 * * * * root /bin/sh /sh/mysql_slave.sh  
记得在每台MySQL从机上分配一个szk5043的用户,权限大些也没关系,只限定在本地运行,如下所示:
mysql>grant all privileges on *.* to szk5043@localhost identified by 'szk5043';
mysql>grant all privileges on *.* to szk5043@127.0.0.1 identified by 'szk5043';

脚本设计思路:

1、此脚本应该能适应各种各样不同的内外网环境,即IP不同的环境;

2、让脚本也顺便监控下MySQL是否正常运行;


2.zabbix监控主从同步

编写一shell脚本,监控slave的两个yes(Slave_IO及Slave_SQL进程),如发现只有一个或零个yes,就表明主从有问题了

___________________________________________________________

a.首先给mysql分配一个监控的账号

mysql> grant replication client on *.* to 'zabbix'@'localhost';

b.编写一个脚本

vim /sh/mysql-replication.sh
#!/bin/bash
/usr/local/mysql/bin/mysql -uzabbix -e 'show slave status\G' |grep -E "Slave_IO_Running|Slave_SQL_Running"|awk '{print $2}'|grep -c Yes

#先用zabbix这个用户来获取slave的所有状态,然后grep出这两个状态,然后再输出第二列,最后查看有几个Yes状态的 ,正常情况下有两个Yes状态。

    其实大家会发现,这只有一条命令,但我却把它写到了一个脚本里面,这里我说一下,因为如果你把命令写到配置文件里面,每次修改完,你都得重启agent,所以写到脚本里面更方便调试修改,这应该是一个好习惯。

c.在agent里面添加监控项

文件的最后添加如下一行

vim /etc/zabbix_agentd.conf 
UserParameter=mysql.replication,/home/zabbix/mysql-replication.sh

#等号后面的字符串中,逗号前面是Key,后面是执行的脚本(脚本不要忘了执行权限) ,添加好之后,就重启agent程序

d.server端添加监控项

zabbix_get -s 192.168.1.202 -p10050 -k "mysql.replication"
2

#这里的192.168.1.202是我的agent的IP ,如果主从复制正常,就会返回2 (代表两个状态都是Yes) 

现在就说明server已经可以从agent获取状态了。 

现在在管理界面中先添加监控项: 

系统配置 -》主机 -》选择要监控的主机的监控项

wKioL1cMm8_AWUtXAACxTwplByc412.png

在右上角选择创建项目

wKioL1cMm9Cg60NLAABQ0rebcC0909.png

创建触发器

wKiom1cMmxvhXoj-AABKKjhNlzQ606.png

wKioL1cMm9CiQ_BEAAAz2C5KRds637.png

e .测试

[root@lab-1-C6 ~]# /etc/init.d/mysqld stop
Shutting down MySQL.. SUCCESS!


wKiom1cMmxzgPM_GAAC1DnnHoMc201.png

#可以设置相应的邮件或短信告警

相关文章
相关标签/搜索