shell监控脚本实例—监控mysql主从复制

 更新时间:2013年11月29日 17:06:50   作者:  
分享一例shell脚本,用于监测mysql数据库的主从复制,有需要的朋友不妨参考学习下

本节内容:
监控mysql主从复制的shell脚本。

说明:
监控脚本在 rhel5 下测试正常,其它版本的linux 系统请自行测试,需要的一些准备工作可以查看这篇文章

代码:

复制代码 代码如下:

#监控mysql 主从复制
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" | 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
#主循环遍历机器 www.jb51.net
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 www.jb51.net
            #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
#

本文出自 “dongnan” 博客

相关文章

  • Linux查看系统时间的详细方法总结

    Linux查看系统时间的详细方法总结

    系统时间是计算机硬件和软件运行的基础,在Linux系统中,查看系统时间是一项基本任务,本文将从多个方面介绍Linux查看系统时间的详细方法,需要的朋友可以参考下
    2023-09-09
  • Linux 中LVS NAT 配置步骤的详解

    Linux 中LVS NAT 配置步骤的详解

    这篇文章主要介绍了Linux 中LVS NAT 配置步骤的详解的相关资料,这里列出详细的实现步骤,需要的朋友可以参考下
    2017-08-08
  • Shell中实现整数自增的几种方法示例

    Shell中实现整数自增的几种方法示例

    Linux Shell中写循环时,常常要用到变量的自增,下面这篇文章主要给大家分享了关于Shell中实现整数变量自增的几种方法,包括declare -i来声明、使用let命令、使用(())以及使用expr命令等等方法,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-08-08
  • linux 中ls命令详解

    linux 中ls命令详解

    ls命令是linux下最常用的命令。ls命令就是list的缩写。下面通过本文给大家分享linux 中ls命令详解,感兴趣的朋友一起看看吧
    2017-09-09
  • Shell echo、printf、test命令的具体使用

    Shell echo、printf、test命令的具体使用

    本文主要介绍了Shell echo、printf、test命令的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-03-03
  • 详解shell 变量的高级用法示例

    详解shell 变量的高级用法示例

    这篇文章主要介绍了详解shell 变量的高级用法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05
  • Shell编程之特殊变量和扩展变量详解

    Shell编程之特殊变量和扩展变量详解

    这篇文章主要给大家介绍了关于Shell编程教程之特殊变量和扩展变量的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用shell具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • Shell最多支持多少个参数?

    Shell最多支持多少个参数?

    这篇文章主要介绍了Shell最多支持多少个参数?本文是对Shell最多可以输入多少个参数的一篇测试文章,需要的朋友可以参考下
    2014-10-10
  • 获取站点的各类响应时间(dns解析时间,响应时间,传输时间)

    获取站点的各类响应时间(dns解析时间,响应时间,传输时间)

    有时候为了测试网络情况,需要返回每个阶段的耗时时间,比如DNS解析耗时,建立连接所消耗的时间,从建立连接到准备传输所使用的时间,从建立连接到传输开始所使用的时间,整个过程耗时,下载的数据量,下载速度,上传数据量,上传速度等等
    2014-03-03
  • Linux Shell 数组建立及使用技巧

    Linux Shell 数组建立及使用技巧

    shell命令在linux系统中是一个非常重要的功能了,我们可以通过它来做N多的事情,本文给大家介绍linux shell 数组建立及使用技巧,需要的朋友可以参考下
    2015-10-10

最新评论