Chinaunix首页 | 论坛 | 博客
  • 博客访问: 211197
  • 博文数量: 109
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 890
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-24 17:06
文章分类

全部博文(109)

文章存档

2015年(1)

2014年(108)

分类: 系统运维

2014-06-05 09:40:35

脚本一:
 
#!/bin/bash
user=***
password=***
echo -e "please inpute slave portarl ip:"
read host

cd `dirname $0`
mysql -u$user -p$password -h$host -e "show slave status\G;" | grep -i running >slave.log
#grep -i, --ignore-case       
#            忽略大小写,包含要搜寻的样式及被搜寻的档案。
if [ `cat slave.log | grep -i io | awk '{print $2}'` = Yes ]
  then
     echo "slave IO process is OK"
else
     echo "slave IO process is error"
fi
if [ `cat slave.log | grep -i sql | awk '{print $2}'` = Yes ]
  then
     echo "slave SQL process is OK"
else
     echo "slave SQL process is error"
fi
rm -rf slave_status

脚本二:

 说明:

脚本在 rhel5 下测试正常,其它版本的 系统请自行测试

代码:
 

复制代码代码示例:
#监控 主从复制
cat chk_mysql_rep.sh 
#!/bin/bash 

#script_name:chk_mysql_rep.sh 
#check mysql replication 

#ssh root@xen "/usr/local/mysql/bin/mysql -uroot -pdongnan -e 'show slave status\G' -ss" |  '/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 -ngnan -e 'show slave status\G' -ss" | awk '/Running:/ {printf $2}') 
    #无法连接的主机,跳过本次循环 
    test -z "$key" &&  
    #返回结果真 
    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 
#
阅读(963) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~