shell获取数据库的主从状态

原来的运维小哥跑路了,目前项目上的运维工作由测试小哥暂时支持,晨会上,测试小哥说目前工作量有些大,其中就说到:每天都要检查各个环境的数据库主从状态。

检查步骤:

1.登录目标服务器

2.登录mysql

3.输入show slave status\G;

4.检查Slave_IO_Running,Slave_SQL_Running,Seonds_Behind_Master等属性的值

这只是一个环境的检查步骤,有几个环境就要重复几次这样的操作,以程序员的思维来讲,这是愚蠢的,非常非常不可取的!!!!

那就来吧,shell脚本干上!(其实我的shell功底也非常一般)

配置文件:checkMysql.conf

#配置需要检查主从状态的目标服务器IP
IP1
IP2
IP3
IP4

脚本文件:checkMysql.sh

#!/bin/bash
conf_file=./checkMysql.conf
while read ip_list
do
Slave_Host=`echo $ip_list | awk -F':' '{print $1}'`
MYSQL_PASS='abc'
Slave_IO_Running=`$MYSQL_BIN/mysql -h$Slave_Host -uuser -p$MYSQL_PASS -e "show slave status\G" 2>&1 |grep Slave_IO_Running|awk '{print $2}' |grep -v "Warning: Using a password"`
Slave_SQL_Running=`$MYSQL_BIN/mysql -h$Slave_Host -uuser -p$MYSQL_PASS -e "show slave status\G" 2>&1 |grep Slave_SQL_Running|awk '{print $2}' |grep -v "Warning: Using a password"`
Seconds_Behind_Master=`$MYSQL_BIN/mysql -h$Slave_Host -uuser -p$MYSQL_PASS -e "show slave status\G" 2>&1 |grep Seconds_Behind_Master|awk '{print $2}' |grep -v "Warning: Using a password"`
echo "***************$Slave_Host**************"
echo "Slave_IO_Running=$Slave_IO_Running"
echo "Slave_SQL_Running=$Slave_SQL_Running"
echo "Seconds_Behind_Master=$Seconds_Behind_Master"
echo ""
done < $conf_file

老铁们可以拿这个shell根据自己的需求进行相应的改动。2>&1 和grep -v "Warning: Using a password"是为了消除登录mysql提示的警告,减少脚本输出

来看一下真实运行情况:

sh checkMysql.sh

测试小哥每天早上拿着这个脚本执行一下就能获取配置文件中所有mysql的主从状态!是不是20分钟的事情一分钟就搞定了,简直一本万利啊!

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值