Chinaunix首页 | 论坛 | 博客
  • 博客访问: 10197892
  • 博文数量: 1669
  • 博客积分: 16831
  • 博客等级: 上将
  • 技术积分: 12594
  • 用 户 组: 普通用户
  • 注册时间: 2011-02-25 07:23
个人简介

柔中带刚,刚中带柔,淫荡中富含柔和,刚猛中荡漾风骚,无坚不摧,无孔不入!

文章分类

全部博文(1669)

文章存档

2023年(4)

2022年(1)

2021年(10)

2020年(24)

2019年(4)

2018年(19)

2017年(66)

2016年(60)

2015年(49)

2014年(201)

2013年(221)

2012年(638)

2011年(372)

分类: 系统运维

2013-11-27 16:52:19

shell监控脚本-监控mysql 主从复制
2013-03-27 13:33:50
标签:mysql shell 主从复制 脚本 监控
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://dngood.blog.51cto.com/446195/1163567
shell监控脚本-监控mysql 主从复制




注意:请先参考 shell监控脚本-准备工作,监控脚本在 rhel5 下测试正常,其它版本的linux 系统请自行测试
#监控mysql 主从复制
cat chk_mysql_rep.sh 
#!/bin/bash 

#script_name:chk_mysql_rep.sh 
#check mysql replication 

#last update 20130320 by dongnan 
#bbs#
#blog# http://dngood.blog.51cto.com 

#ssh root@xen "/usr/local/mysql/bin/mysql -uroot -pdongnan -e 'show slave status\G' -ss" | awk '/Running:/ {print $2}' 
#Yes 
#Yes 

#variables 
ssh=/usr/bin/ssh 
sh_dir=/root/sh/ 
crondir=${sh_dir}crontab 
source ${sh_dir}CONFIG 
hosts="$DB_SLAVE_HOSTS"
#main 
#主循环遍历机器 
for HOST in $hosts;do 
log=$crondir/log/mysql_replication_error.log 
key=$($ssh root@$HOST "/usr/local/mysql/bin/mysql -uroot -pdongnan -e 'show slave status\G' -ss" | awk '/Running:/ {printf $2}') 
    #无法连接的主机,跳过本次循环 
    test -z "$key" && continue 
    #返回结果真 
    if [ "$key" == "YesYes" ];then 
        #flag真,解除报警 
        if [ -f "${crondir}/log/$HOST.mysql" ];then 
            #sms 
            #for mobile in $MOBILES;do 
                #echo "$HOST replication ok" | /usr/local/bin/gammu --sendsms TEXT "$mobile" -unicode 
            #done 
            #mail 
            for mail in $MAILS;do 
                echo "$HOST replication ok" | mail -s "$HOST replication ok" $mail 
            done 
            #flag 
            rm -f "${crondir}/log/$HOST.mysql" 
        fi 
    #返回结果假 
    else   
check_date=$(date '+ %F %T') 
        #flag假,报警 
        if [ ! -f "${crondir}/log/$HOST.mysql" ];then 
            #sms 
            #for mobile in $MOBILES;do 
                #echo "$HOST replication error" | /usr/local/bin/gammu --sendsms TEXT "$mobile" -unicode 
            #done 
            #mail 
            for mail in $MAILS;do 
                echo "$HOST replication error" | mail -s "$HOST replication error" $mail 
            done 
            #flag 
            echo "replication error" >"${crondir}/log/$HOST.mysql" 
            #log 
            echo "$check_date $HOST mysql replicaton error" >> $log 
        fi 
    fi 

done 

结束
更多请:  
linux 系统运维  37275208  
vmware 虚拟化  166682360
本文出自 “dongnan” 博客,请务必保留此出处http://dngood.blog.51cto.com/446195/1163567
阅读(989) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~