zoukankan      html  css  js  c++  java
  • 监控mysql主从同步状态

    在高并发网站架构中,MySQL数据库主从同步是不可或缺的,不过经常会发生由于网络原因或者操作错误,MySQL主从经常会出现不同步的情况,那么如何监控MySQL主从同步,也变成网站正常运行的重要环节。

    MySQL同步功能由3个线程(master上1个,slave上2个)来实现,简单的说就是:master发送日志一个,slave接收日志一个,slave运行日志一个。

    首先,我们解释一下 show slave status  中重要的几个参数:
    Slave_IO_Running: I/O线程是否被启动并成功地连接到主服务器上。

    Slave_SQL_Running: SQL线程是否被启动。

    Seconds_Behind_Master:和主库比同步延迟的秒数

    本字段是从属服务器“落后”多少的一个指示。当从属SQL线程正在运行时(处理更新),本字段为在主服务器上由此线程执行的最近的一个事件的时间标记开始,已经过的秒数。当此线程被从属服务器I/O线程赶上,并进入闲置状态,等待来自I/O线程的更多的事件时,本字段为零。总之,本字段测量从属服务器SQL线程和从属服务器I/O线程之间的时间差距,单位以秒计。

    如何监控从服务器是否正常运行呢?

    [root@slave ~]# mysql -u root -proot -e "show slave statusG;"
    *************************** 1. row ***************************
                   Slave_IO_State: Waiting for master to send event
                      Master_Host: 192.168.0.31    #当前的mysql master服务器主机
                      Master_User: myslave
                      Master_Port: 3306
                    Connect_Retry: 60
                  Master_Log_File: master-bin.000003
              Read_Master_Log_Pos: 471
                   Relay_Log_File: relay-log-bin.000002
                    Relay_Log_Pos: 252
            Relay_Master_Log_File: master-bin.000003
                 Slave_IO_Running: Yes                 #I/O线程是否被启动并成功地连接到主服务器上。
                Slave_SQL_Running: Yes                 #SQL线程是否被启动。
                         Master_SSL_Key: 
                               Seconds_Behind_Master: 0    #和主库比同步延迟的秒数
    

     下面编写shell脚本监控mysql主从同步,实现如下功能:

    阶段1:开发一个守护进程脚本每30秒实现检测一次。

    阶段2:如果同步出现如下错误号(1158,1159,1008,1007,1062),请跳过错误

    阶段3:请使用数组技术实现上述脚本(获取主从判断及错误号部分)

    #!/bin/bash
    mysql_cmd="mysql -u root -proot"
    errornum=(1158 1159 1008 1007 1062)
    while true
    do
      array=($($mysql_cmd -e "show slave statusG"|egrep ‘_Running|Behind_Master|Last_SQL_Errno‘|awk ‘{print $NF}‘))
      if [ "${array[0]}" == "Yes" -a "${array[1]}" == "Yes" -a "${array[2]}" == "0" ]
      then
        echo "MySQL is slave is running"
      else
          for ((i=0;i<${#errornum[*]};i++))
          do
            if [ "${array[3]}" = "${errornum[$i]}" ];then
            $mysql_cmd -e "stop slave &&set global sql_slave_skip_counter=1;start slave;"
            fi
          done
          char="MySQL slave is downed"
          echo "$char"
          echo "$char"|mail -s "$char" xxxxx@qq.com
          break
      fi
      sleep 30
    done
    
  • 相关阅读:
    JQ常用代码
    websocket练习
    动软生成器 model生成模板
    动软生成器 Liger model生成模板
    SVN各种错误提示产生原因及处理方法大全
    winfom实现关闭后一直运行
    在yii中使用分页
    html文字垂直居中
    给浏览器网页标签页添加图标
    html 遇到margin居中的问题
  • 原文地址:https://www.cnblogs.com/Dev0ps/p/8379819.html
Copyright © 2011-2022 走看看