mysql复制延迟监控脚本
- #!/bin/sh
- #ocpyang@126.com
- #repdelay.sh
- #查看复制延迟详细多少event
- #####1.juede the rep slave status
- export black='\033[0m'
- export boldblack='\033[1;0m'
- export red='\033[31m'
- export boldred='\033[1;31m'
- export green='\033[32m'
- export boldgreen='\033[1;32m'
- export yellow='\033[33m'
- export boldyellow='\033[1;33m'
- export blue='\033[34m'
- export boldblue='\033[1;34m'
- export magenta='\033[35m'
- export boldmagenta='\033[1;35m'
- export cyan='\033[36m'
- export boldcyan='\033[1;36m'
- export white='\033[37m'
- export boldwhite='\033[1;37m'
- cecho ()
- ## -- Function to easliy print colored text -- ##
- # Color-echo.
- # 參数 $1 = message
- # 參数 $2 = color
- {
- local default_msg="No message passed."
- message=${1:-$default_msg} # 假设$1没有输入则为默认值default_msg.
- color=${2:-black} # 假设$1没有输入则为默认值black.
- case $color in
- black)
- printf "$black" ;;
- boldblack)
- printf "$boldblack" ;;
- red)
- printf "$red" ;;
- boldred)
- printf "$boldred" ;;
- green)
- printf "$green" ;;
- boldgreen)
- printf "$boldgreen" ;;
- yellow)
- printf "$yellow" ;;
- boldyellow)
- printf "$boldyellow" ;;
- blue)
- printf "$blue" ;;
- boldblue)
- printf "$boldblue" ;;
- magenta)
- printf "$magenta" ;;
- boldmagenta)
- printf "$boldmagenta" ;;
- cyan)
- printf "$cyan" ;;
- boldcyan)
- printf "$boldcyan" ;;
- white)
- printf "$white" ;;
- boldwhite)
- printf "$boldwhite" ;;
- esac
- printf "%s\n" "$message"
- tput sgr0 # tput sgr0即恢复默认值
- printf "$black"
- return
- }
- cechon ()
- # Color-echo.
- # 參数1 $1 = message
- # 參数2 $2 = color
- {
- local default_msg="No message passed."
- # Doesn't really need to be a local variable.
- message=${1:-$default_msg} # 假设$1没有输入则为默认值default_msg.
- color=${2:-black} # 假设$1没有输入则为默认值black.
- case $color in
- black)
- printf "$black" ;;
- boldblack)
- printf "$boldblack" ;;
- red)
- printf "$red" ;;
- boldred)
- printf "$boldred" ;;
- green)
- printf "$green" ;;
- boldgreen)
- printf "$boldgreen" ;;
- yellow)
- printf "$yellow" ;;
- boldyellow)
- printf "$boldyellow" ;;
- blue)
- printf "$blue" ;;
- boldblue)
- printf "$boldblue" ;;
- magenta)
- printf "$magenta" ;;
- boldmagenta)
- printf "$boldmagenta" ;;
- cyan)
- printf "$cyan" ;;
- boldcyan)
- printf "$boldcyan" ;;
- white)
- printf "$white" ;;
- boldwhite)
- printf "$boldwhite" ;;
- esac
- printf "%s" "$message"
- tput sgr0 # tput sgr0即恢复默认值
- printf "$black"
- return
- }
- ####2.jude the rep delay status
- #configure rep master and slave env
- masterhost="192.168.99.137"
- slavehost="192.168.1.220"
- mysql_user=root #mysql的username
- mysql_pass='123' #mysql的登录用户password
- SQLresponse=`mysql -h${slavehost} -u${mysql_user} -p${mysql_pass} mysql -e "show slave status \G" |grep '\<Slave_SQL_Running\>'|awk '{print $2}'`
- IOresponse=`mysql -h${slavehost} -u${mysql_user} -p${mysql_pass} mysql -e "show slave status \G" |grep '\<Slave_IO_Running\>'|awk '{print $2}'`
- Behind=`mysql -h${slavehost} -u${mysql_user} -p${mysql_pass} mysql -e "show slave status \G" |grep '\<Seconds_Behind_Master\>'|awk '{print $2}'`
- if [ "$SQLresponse" = "No" ]; then
- echo " "
- error="mysqlserver($slavehost)的复制已经停止工作:Slave_SQL_Running: No;无法获取复制延迟情况."
- cechon "${error}" red
- echo " "
- exit 0
- fi
- if [ "$IOresponse" = "No" ]; then
- echo " "
- error="mysqlserver($slavehost)的复制已经停止工作:Slave_IO_Running: No;无法获取复制延迟情况."
- cechon "${error}" red
- echo " "
- exit 0
- fi
- #set mysql evn
- MYSQL_USER_MASTER=root
- MYSQL_PASS_MASTER='123'
- MYSQL_HOST_MASTER=192.168.99.137
- MYSQL_USER_SLAVE=root
- MYSQL_PASS_SLAVE='123'
- MYSQL_HOST_SLAVE=192.168.1.220
- tmpfile_01="tmp01.`date +%Y%m%d%H%M%S`.txt"
- tmpfile_02="tmp02.`date +%Y%m%d%H%M%S`.txt"
- mysql -h${MYSQL_HOST_MASTER} -u${MYSQL_USER_MASTER} -p${MYSQL_PASS_MASTER} -e"SHOW BINARY LOGS;" >${tmpfile_01}
- mysql -h${MYSQL_HOST_SLAVE} -u${MYSQL_USER_SLAVE} -p${MYSQL_PASS_SLAVE} -e"SHOW SLAVE STATUS\G;" >${tmpfile_02}
- #tail -1 ${tmpfile_01} | grep -v "Log_name"
- #cat ${tmpfile_02} | grep -E 'Master_Log_File|Read_Master_Log_Pos|Exec_Master_Log_Pos' | grep -v "Relay_Master_Log_File" |sed 's/^[ ]*//g'
- a=`tail -1 ${tmpfile_01} | grep -v "Log_name" |awk '{print $1}'|awk -F "." '{print $2}'`
- b=`sed -n "/\<Relay_Master_Log_File\>/p" ${tmpfile_02} |sed 's/^[ ]*//g' |awk -F ":" '{print $2}'|awk -F "." '{print $2}'`
- bhtime=`sed -n "/\<Seconds_Behind_Master\>/p" ${tmpfile_02} |sed 's/^[ ]*//g' |awk -F ":" '{print $2}'`
- if [ "$b" = "$a" ];then
- c=`tail -1 ${tmpfile_01} | grep -v "Log_name" |awk '{print $2}'`
- d=`sed -n "/\<Read_Master_Log_Pos\>/p" ${tmpfile_02} |sed 's/^[ ]*//g' |awk -F ":" '{print $2}'`
- k=`sed -n "/\<Exec_Master_Log_Pos\>/p" ${tmpfile_02} |sed 's/^[ ]*//g' |awk -F ":" '{print $2}'`
- e=`expr $c - $d`
- dfevt=`expr $d - $k`
- if [ "${e}" -eq 0 -a "${bhtime}" -eq 0 -a "${k}" -eq 0 ] ; then
- echo "*****************************************************************************"
- echo -e "\e[1;31m &&&&&&&Synchronization has been completed!&&&&&&& \e[0m"
- echo "*****************************************************************************"
- elif [ "${e}" -eq 0 -o "${bhtime}" -gt 0 ] ; then
- echo "*****************************************************************************"
- echo -e "\e[1;31m Has been synchronized to the same log file! Wait a moment \e[0m"
- echo -e "\e[1;31m Not synchronized binlog events is:${dfevt},behind master tims is ${bhtime} \e[0m"
- echo "*****************************************************************************"
- fi
- elif [ ${b} -lt ${a} ];then
- exbin=`sed -n "/\<Exec_Master_Log_Pos\>/p" ${tmpfile_02} |sed 's/^[ ]*//g' |awk -F ":" '{print $2}'`
- y=`sed -n "/\<Relay_Master_Log_File\>/p" ${tmpfile_02} |sed 's/^[ ]*//g' |awk -F ":" '{print $2}'`
- #u=`awk '{if($1~/'''''$y'''''/ ) print NR}' ${tmpfile_01}`
- u=`grep -n "$y" ${tmpfile_01}|awk -F: '{print $1'}`
- x=`awk 'NR>='''$u''' { print $0}' ${tmpfile_01}|awk 'BEGIN{total=0}{total+=$2}END{print total}' `
- re=`expr $x - $exbin`
- echo -e "\e[1;31m There are multiple log files are not synchronized,the events is:${re} \e[0m"
- fi
- rm -rf ${tmpfile_01}
- rm -rf ${tmpfile_02}
mysql复制延迟监控脚本的更多相关文章
- MySQL至TiDB复制延迟监控
因生产环境mysql中有较多复杂sql且运行效率低,因此采用tidb作为生产环境的从库进行部分慢sql及报表的读写分离.其中MySQL至TIDB采用Syncer工具同步.关于TIDB的安装及Synce ...
- MySQL慢日志监控脚本实例剖析
公司线上的 MySQL 慢日志,之前一直没有做好监控.趁着上周空闲,我就把监控脚本写了下,今天特地把代码发出来与51博友分享一下. 针对脚本的注解和整体构思,我会放到脚本之后为大家详解. 1 2 3 ...
- pt-heartbeat工具监控MySQL复制延迟
pt-heartbeat工作原理: 1,在主库上的某个数据库A中创建一张heartbeat表,按照一定的时间频率更新该表的字段(把时间更新进去). 2,从主库连接到从上的这个数据库A中检查复制的时间记 ...
- mysql复制延迟排查
今天收到报警,提示从库延时,首先当然是上去查看情况,首先查看机器负载,如下: 可以看到使用cpu已经100%,io没有等待.那么查看mysql是什么情况,执行show processlist没有发现任 ...
- mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理
转自:http://www.cnblogs.com/kevingrace/p/6261091.html 在mysql工作中接触最多的就是mysql replication mysql在复制方面还是会有 ...
- MySQL复制中slave延迟监控
在MySQL复制环境中,我们通常只根据 Seconds_Behind_Master 的值来判断SLAVE的延迟.这么做大部分情况下尚可接受,但并不够准确,而应该考虑更多因素. 首先,我们先看下SLAV ...
- MySQL 5.7--复制延迟监控
========================================== SHOW PROCESSLIST方式 为保证二进制日志在从库的执行时间和顺序的正确性,二进制日志中的每个语句都设置 ...
- MySQL 5.7并发复制和mysqldump相互阻塞引起的复制延迟
本来MySQL BINLOG和mysqldump命令属于八竿子打不着的两个事物,但在最近故障排查中,发现主库和从库已经存在很严重的复制延迟,但从库上显示slave_behind_master值为0,复 ...
- [MySQL] 号称永久解决了复制延迟问题的并行复制,MySQL5.7
一.缘由: 某天看到主从复制延时的告警有点频繁,就想着是不是彻底可以解决一下. 一般主从复制,有三个线程参与,都是单线程:Binlog Dump(主) ----->IO Thread (从) - ...
随机推荐
- 背景渐变 background-image:linear-gradient(0deg,#fff,#ccc);
背景渐变 background-image:linear-gradient(0deg,#fff,#ccc);
- CE工具里自带的学习工具--第五关
图解: 此时会弹出一个对话框,选择是就可以了,最终会看到:
- CAD参数绘制多行文字(com接口)
在CAD设计时,需要绘制多行文字,用户可以设置设置绘制文字的高度等属性. 主要用到函数说明: _DMxDrawX::DrawMText 绘制一个多行文字.详细说明如下: 参数 说明 DOUBLE dP ...
- C++ 线程同步的四种方式
程之间通信的两个基本问题是互斥和同步. (1)线程同步是指线程之间所具有的一种制约关系,一个线程的执行依赖另一个线程的消息,当它没有得到另一个线程的消息时应等待,直到消息到达时才被唤醒. (2)线程互 ...
- JavaSE-11 接口
学习要点 接口的定义 接口作为约定 接口作为能力 接口 为什么使用接口 需求描述 要求实现防盗门的功能(防盗门:带锁的门). 需求分析 门有“开”和“关”的功能,锁有“上锁”和“开锁”的功能. 将门和 ...
- 第1节 yarn:14、yarn集群当中的三种调度器
yarn当中的调度器介绍: 第一种调度器:FIFO Scheduler (队列调度器) 把应用按提交的顺序排成一个队列,这是一个先进先出队列,在进行资源分配的时候,先给队列中最头上的应用进行分配资源 ...
- [实现] 利用 Seq2Seq 预测句子后续字词 (Pytorch)
最近有个任务:利用 RNN 进行句子补全,即给定一个不完整的句子,预测其后续的字词.本文使用了 Seq2Seq 模型,输入为5个中文字词,输出为一个中文字词. 目录 关于RNN 语料预处理 搭建数据集 ...
- [bzoj2806][Ctsc2012]Cheat(后缀自动机(SAM)+二分答案+单调队列优化dp)
偷懒直接把bzoj的网页内容ctrlcv过来了 2806: [Ctsc2012]Cheat Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 1943 ...
- JavaScript关键字
JavaScript关键字 制作人:全心全意 abstract continue finally instanceof private this boolean default float int p ...
- buf.values()
buf.values() 返回:{Iterator} 创建并返回一个包含 Buffer 值(字节)的迭代器.当 Buffer 使用 for..of 声明时将自动调用该函数. const buf = B ...