MySQL:shell手动监控db存活及slave状态

1、所有db信息

all_db.txt

192.168.x.x     3306 S
192.168.x.x     3306 M

2、检查脚本

check_all_db.sh

#!/bin/bash

user='' 
password=''
errFile=/tmp/sms_mon_db.txt

call(){
for phone in 186xxxx
do
    curl "短信接口:{$ip}+{$port}+{$stat}"
    echo "[ `date +"%Y-%m-%d %H:%M:%S"` ] {$ip}+{$port}+{$stat}"| tee -a $errFile
done
}

dbcount=`cat /shell/all_db.txt |grep -v '^#'|grep -v '^$'| wc -l` 

#检查数据库是否存活
for((i=1;i<=$dbcount;i++))
do
  ip=`cat /shell/all_db.txt |grep -v '^#'|grep -v '^$'|awk -F" " '{print $1}'|sed -n "$i p"`
  port=`cat /shell/all_db.txt |grep -v '^#'|grep -v '^$'|awk -F" " '{print $2}'|sed -n "$i p"`
  dbstat=`/usr/local/mysql/bin/mysqladmin -u$user -p$password -h$ip -P$port ping |grep alive|wc -l`
  stat='down'

  if [ $dbstat -ne 1 ]
        then call
  fi
done

#检查slave状态
for((i=1;i<=$dbcount;i++))
do
  ip=`cat /shell/all_db.txt |grep -v '^#'|grep -v '^$'|awk -F" " '{print $1}'|sed -n "$i p"`
  port=`cat /shell/all_db.txt |grep -v '^#'|grep -v '^$'|awk -F" " '{print $2}'|sed -n "$i p"`
  is_slave=`cat /shell/all_db.txt |grep -v '^#'|grep -v '^$'|awk -F" " '{print $3}'|sed -n "$i p"`
  
  if [ $is_slave = 'S' ]
    then
      status_array=($(/usr/local/mysql/bin/mysql -u$user -p$password -h$ip -P$port -e "show slave status\G"|grep Running|awk -F : '{print $2}'))
      stat='slave+error'
  
      if [ "${status_array[0]}" != "Yes" ] || [ "${status_array[1]}" != "Yes" ]
      then call
      fi
  fi
done


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值