zoukankan      html  css  js  c++  java
  • zabbix监控mysql主从

    1.写一个监控脚本

    这个脚本主要用于获取MYSQL主从同步信息;

    我们先执行一个命令

    mysql -u zabbix -e 'show slave statusG'

    我们在输出的信息中选择

    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes

    这两项来监控,我测试了一下,当操作的数据出现异常的时候,Slave_SQL_Running就会变成No,当执行slave stop的时候,两个都会变成No;

    脚本内容如下

    #!/bin/bash
    mysql -uzabbix -e 'show slave statusG' |grep -E "Slave_IO_Running|Slave_SQL_Running"|awk '{print $2}'|grep -c Yes

    我只写了一条命令,这里详细说明一下它的意思;

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

    2   zabbix agent里面添加监控项

    文件的最后添加如下一行

    UserParameter=mysql.replication,/home/zabbix/mysql-replication.sh

    等号后面的字符串中,逗号前面是Key,后面是执行的脚本(脚本不要忘了执行权限)

    添加好之后,就重启agent程序

    3、Server端添加监控项

    zabbix_get -s 192.168.0.34 -k "mysql.replication"
    2

    这里的192.168.0.34 是我的agent的IP,如果主从复制正常,就会返回2 (代表两个状态都是Yes),现在就说明Server已经可以从agent获取状态了,现在在管理界面中先添加监控项:

    配置 --模板

    先创建一个模板,这个模板的主要功能是用于监视MYSQL主从复制的状态;

    添加触发器

    当返回的值小于2时,说明只存在1个YES或0个YES,这时候说明MYSQL主从同步出现异常,即产生报警;

    获取最新数据

    在这里可以看到,已经获取了最新的监控数据,说明监控添加成功;

  • 相关阅读:
    10年后方向
    nginx的配置文件server_name的意义 location意义
    java程序员应该知道的20个有用的库
    集群和分布式区别
    noVNC连接CentOS,以Web方式交付VNC远程连接
    centos7.2云主机安装桌面
    centos7.2 rabbitmq3.6.2源码部署
    Linux下打包压缩war和解压war包 zip和jar
    CentOS7.2下安装mongoDB3.2.8
    centos7 mysql5.7.17源码安装
  • 原文地址:https://www.cnblogs.com/yangxiaochu/p/8310514.html
Copyright © 2011-2022 走看看