mysql主从延迟监控脚本_MySQL主从延迟监控脚本(pt-heartbeat)

利用percona的pt-heartbeat工具,本文介绍了如何通过shell脚本定期检查并监控MySQL主从复制的延迟情况。当延迟超过预设阈值时,脚本将启动持续监控并将详细信息记录到日志,并发送邮件通知。
摘要由CSDN通过智能技术生成

对于MySQL数据库主从复制延迟的监控,我们可以借助percona的有力武器pt-heartbeat来实现。pt-heartbeat通过使用时间戳方式在主库上更新特定表,然后在从库上读取被更新的时间戳然后与本地系统时间对比来得出其延迟。本文主要是通过脚本来定期检查从库与主库复制的延迟度并发送邮件,供大家参考。

有关pt-heartbeat工具的安装可以参考:percona-toolkit的安装及简介

有关pt-heartbeat工具的介绍可以参考:使用pt-heartbeat监控主从复制延迟

1、脚本概述 a、脚本定期使用--check方式单次检查当前的延迟性(定期的方式可以使用cron job比如每1分钟或5分钟)

b、通过设定指定的延迟阀值来判断当时的延迟性是否在可控范围

c、一旦当前的延迟大于指定阀值,则马上使用--monitor方式不停的监控其延迟性并写入到日志文件

d、对于--monitor方式,其进程运行超过30分钟,自kill其进程,以避免无限期运行导致日志过大,空间不够用

2、脚本内容[mysql@SZDB run]$ more ck_slave_lag.sh

#!/bin/bash

#set -x

if [ $# -ne 3 ];then

echo "usage:"

echo "ck_slave_lag.sh "

exit 0;

fi

# Author : Leshami

# Blog : http://www.gxlcms.com/

ServerID=$1

MaxLag=$2

LogDir=$3

Timestamp=`date +%Y%m%d_%H%M%S`

Rentition=7

LogFile=$LogDir/slave_lag_$Timestamp.log

LagDetail=$LogDir/slave_lag_Detail_$Timestamp.log

mailadd=leshami@12306.cn

echo $ServerID

echo $MaxLag

echo $LogDir

echo $LogFile

echo $LagDetail

echo $mailadd

if [ ! -d $LogDir ];then

mkdir -p $LogDir

fi

Lag=`/usr/bin/pt-heartbeat --user=monitor --password=xxx -S /tmp/mysql.sock -D test --master-server-id=$ServerID --check`

Lag=`echo ${Lag%.*}`

#Lag=3

echo $Lag

ptStatus=`ps -ef|grep pt-heart|grep daemonize`

echo $ptStatus

if [ $Lag -gt $MaxLag ]; then

echo "The current date is `date` at `hostname`." >>$LogFile

echo "The current lag log file is $LogFile." >>$LogFile

echo "The current replication lag is $Lag." >>$LogFile

echo "The replication lag is larger than max lag $MaxLag." >>$LogFile

if [ -z "$ptStatus" ] ; then

echo "Start a monitor daemon with below command: " >>$LogFile

echo "pt-heartbeat --user=monitor --password=xxx -S /tmp/mysql.sock -D test " >>$LogFile

echo " --master-server-id=11 --monitor --print-master-server-id --daemonize --log=$LagDetail" >>$LogFile

/usr/bin/pt-heartbeat --user=monitor --password=xxx -S /tmp/mysql.sock -D test \

--master-server-id=$ServerID --monitor --print-master-server-id --daemonize --log=$LagDetail

echo "More detail please check lag log from $LagDetail." >>$LogFile

cat $LogFile | mutt -s "Found slave lag on `hostname`." $mailadd

fi

fi

if [ -n "$ptStatus" ] ; then

STime=`ps -ef|grep pt-heart|grep daemonize |gawk '{print $5}'`

Pid=`ps -ef|grep pt-heart|grep daemonize |gawk '{print $2}'`

STime=`date '+%Y%m%d'`" "$STime

s_STime=`date -d "$STime" '+%s'`

s_ETime=`date +%s`

DiffSec=`expr $s_ETime - $s_STime`

echo $STime

echo $s_STime

echo $s_ETime

echo $DiffSec

if [ "$DiffSec" -gt 1800 ]; then

echo "kill -9 $Pid"

kill -9 $Pid

fi

fi

# Remove history slave lag log.

find $LogDir -name "*slave_lag*" -ctime +$Rentition -delete

exit

3、部署参考[mysql@SZDB run]$ crontab -l

#check slave lag

*/1 * * * * /run/ck_slave_lag.sh 11 3 /log/SlaveLag

以上就是MySQL 主从延迟监控脚本(pt-heartbeat)的内容,更多相关内容请关注PHP中文网(www.gxlcms.com)!

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
排查 MySQL 主从延迟问题的过程通常如下: 1. 检查主服务器状态:连接到主服务器,并使用以下命令检查主服务器的状态信息: ```sql SHOW MASTER STATUS; ``` 确保主服务器的日志文件名称和位置。 2. 检查从服务器状态:连接到从服务器,并使用以下命令检查从服务器的状态信息: ```sql SHOW SLAVE STATUS; ``` 确保从服务器的主日志文件名称和位置与主服务器一致。 3. 检查复制线程状态:在从服务器上执行 `SHOW SLAVE STATUS;` 命令后,查看以下字段: - `Slave_IO_Running`:确保该值为 "Yes",表示复制 IO 线程正在运行。 - `Slave_SQL_Running`:确保该值为 "Yes",表示复制 SQL 线程正在运行。 - `Seconds_Behind_Master`:表示当前从服务器相对于主服务器的延迟时间(以秒为单位)。确保该值不断减小,或为0。 4. 检查网络连接:确保主服务器和从服务器之间的网络连接良好,没有丢包或延迟。可以使用 ping 命令测试网络连接。 ```bash ping <主服务器IP> ping <从服务器IP> ``` 5. 检查主服务器负载:如果主服务器负载过高,可能会导致主从延迟。使用以下命令检查主服务器的负载情况: ```sql SHOW PROCESSLIST; ``` 确认是否有大量的写入操作正在进行,如果有,请考虑优化数据库或增加硬件资源来减轻负载。 6. 检查从服务器负载:如果从服务器负载过高,也可能导致主从延迟。使用以下命令检查从服务器的负载情况: ```sql SHOW PROCESSLIST; ``` 确认是否有大量的读取操作正在进行,并考虑优化查询或增加硬件资源来减轻负载。 7. 检查复制延迟原因:如果上述步骤都没有找到延迟的原因,可以尝试以下方法: - 检查从服务器的错误日志,查看是否有错误信息或警告。 - 使用 Percona Toolkit 工具集中的 pt-heartbeatpt-slave-delay 工具来监控主从延迟情况。 - 分析慢查询日志,查看是否有影响复制性能的查询。 通过以上步骤逐一排查,可以帮助您找出 MySQL 主从延迟的原因。根据具体情况可能需要结合实际的复制配置和数据库负载情况来进行排查。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值