本帖最后由 qddf 于 2016-12-15 09:21 编辑
在高并发网站架构中,MySQL数据库主从同步是不可或缺的,不过经常会发生由于网络原因或者操作错误,MySQL主从经常会出现不同步的情况,那么如何监控MySQL主从同步,也变成检测网站正常运行的重要环节。
MySQL同步功能由3个线程(master上1个,slave上2个)来实现,简单的说就是:master发送日志一个,slave接收日志一个,slave运行日志一个。
Slave_io_Running:yes
Slave_SQL_Running: yes
这两个同时为yes时,表示主从同步,有一个变为no,同步失败
我们需要写一个脚本,来检测这两个参数的状态
cat mysql-replication.sh
#!/bin/bash
mysql -uroot
-p***-e 'show slave status\G' |grep -E "Slave_IO_Running|Slave_SQL_Running"|awk '{print $2}'|grep -c Yes
测试脚本时 出现如下错误
Warning: Using a password on the command line interface can be insecure.
2
这时检测端接受的数据是 错误和数据 无法被检测端接受
可以在my.cnf 中 [mysqld] 增加mysql 和 password 我们还可以给数据库一个没有密码的账户
mysql -uroot -p密码
mysql> grant replication client on *.* to 'zabbix'@'localhost';
测试将脚本更改为
#!/bin/bash
mysql -uzabbix -e 'show slave status\G' |grep -E "Slave_IO_Running|Slave_SQL_Running"|awk '{print $2}'|grep -c Yes
测试脚本显示如下
2
当显示1或者0的时候即为同步出现了问题
在 zabbix agent里面添加监控项 vim /usr/local/zabbix-3.0.4/etc/zabbix_agentd.conf
UserParameter=mysql.replication,/usr/local/zabbix-3.0.4/bin/mysql-replication.sh
等号后面的字符串中,逗号前面是Key,后面是执行的脚本(脚本不要忘了执行权限)
重启zabbix agent
在zabbix server做测试 看是否可以接受到数据
[iyunv@zabbix bin]# ./zabbix_get -s 192.168.2.44 -k "mysql.replication"
2
表示成功
在监控界面增加监控项和触发器
当返回的值小于2时,说明只存在1个YES或0个YES,这时候说明MYSQL主从同步出现异常,即产生报警;
此时在从库中执行stop slave ;
接收到邮件
启动salve start slave
收到回复邮件
增加主从监控成功
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com