行业资讯 2025年08月6日
0 收藏 0 点赞 920 浏览 1177 个字
摘要 :

文章目录 1、同步状态参数查看 2、使用脚本监控同步状态 MySQL主从同步或者主从复制,往往会存在数据同步延迟的情况,如果延迟较大,可能是影响生产,因此我们就需要对……




MySQL主从同步或者主从复制,往往会存在数据同步延迟的情况,如果延迟较大,可能是影响生产,因此我们就需要对mysql主从同步或复制延迟状态进行监控。下面潘老师演示下使用shell脚本简单地实现状态监控。

1、同步状态参数查看

首先我们要只要主从复制的参数在哪查看,其实在MySQL8主从复制(一主一从)配置搭建详解的时候就已经使用该指令,登录mysql后,使用如下指令:

show slave status \\G

可以看到很多参数,其中有一个参数名为Seconds_Behind_Master,取值一般为NULL或者0和大于0的值,这个参数就是主从同步延迟参数,单位是秒。
但是监控主从同步状态一般会看如下3个参数:

  • Slave_IO_Running: I/O线程是否被启动并成功地连接到主服务器上。
  • Slave_SQL_Running: SQL线程是否被启动。
  • Seconds_Behind_Master:和主库比同步延迟的秒数

比较期待的结果就是Slave_IO_Running=Yes,Slave_SQL_Running=Yes,Seconds_Behind_Master=0

2、使用脚本监控同步状态

#!/bin/bash
mysql_cmd="mysql -u root -p密码"
errornum=(1158 1159 1008 1007 1062)
while true
do
  array=($($mysql_cmd -e "show slave status\\G"|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

该脚本没30秒会监控一次同步状态参数,当以上3个参数出现异常时就会发一封邮件到你的邮箱。

当然,这些使用脚本的方案都是比较容易掌握且好理解的,但是功能还是有限,想要更好地监控主从同步复制状态还是要使用第三方的工具,比如Percona Toolkit这一类的,功能更加强大。

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/8177.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

988
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

465
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

348
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

456
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

517
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

832
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号