教程集 www.jiaochengji.com
教程集 >  脚本编程  >  shell  >  正文 shell写的告警次数控制及恢复示例

shell写的告警次数控制及恢复示例

发布时间:2014-09-24   编辑:jiaochengji.com
自己写的一个监控脚本,发现告警短信次数未控制时,垃圾短信N多。<br /> 经过思考,做了个简单的控制,同一故障只发送二次。之后不再发送。恢复后发送恢复短信。

自己写的一个监控脚本,发现告警短信次数未控制时,垃圾短信N多。
经过思考,做了个简单的控制,同一故障只发送二次。之后不再发送。恢复后发送恢复短信。

俺也是新手,写的有点老土,权当练手了,供初学的朋友们参考吧。
 

复制代码 代码如下:

#!/bin/bash

if [ $succ_ping -gt $((ping_count-1)) ];then
if [ -f ./alarm_file/alarm_$host ];then
  rm -rf ./alarm_file/alarm_$host
  #发送故障消除短信通知--调用insert_table
  messages="$host服务器通迅恢复正常`date "+%Y%m%d %H:%M:%S"`"
  echo "$messages" >>./log/ping_err_recover.log
  insert_table
else
  echo "本次检测结果---->$host服务器ping检测正常"
  echo "`date "+%Y%m%d %H:%M:%S"`--->$host服务器ping检测正常,ping次数$ping_count,接收$succ_ping" >>./log/ping_log
fi
else
  echo "本次检测结果---->$host服务器有丢包现象,丢包率为:$loss_ping"
  messages="`date "+%Y%m%d %H:%M:%S"`--->$host服务器有丢包现象,丢包率为:$loss_ping"
  #对警次数进行处理,超过2次将不告警
  #格式host a(告警次数)
  #已经出现告警的次数加1
  echo "告警服务器为$host"
  if [ -f ./alarm_file/alarm_$host ];then
     #取出当前的告警次数并加1
     a=`awk '{print$2}' ./alarm_file/alarm_$host`
     b=$(($a+1))
     echo "$host $b" >./alarm_file/alarm_$host
     alarm_count=`awk '{print$2}' ./alarm_file/alarm_$host`
       if [ $alarm_count -gt $sms_count ];then
          echo "超过2次不发送短信"
          echo "`date "+%Y%m%d %H:%M:%S"`--->$host服务器有丢包现象,接收$succ_ping,丢包率为:$loss_ping,超过二次不发送。" >>./log/ping_err_log
      else
          #未超过2次调用insert_table函数发送短信
          echo "未超过2次"
          echo "`date "+%Y%m%d %H:%M:%S"`--->$host服务器有丢包现象,接收$succ_ping,丢包率为:$loss_ping">>./log/ping_err_log
          insert_table
      fi
  else
   #第一次告警
   echo "第一次告警"
   echo "$host 1" >./alarm_file/alarm_$host
   insert_table
   echo "`date "+%Y%m%d %H:%M:%S"`--->$host服务器有丢包现象,接收$succ_ping,丢包率为:$loss_ping" >>./log/ping_err_log
  fi
fi
done

您可能感兴趣的文章:
shell写的告警次数控制及恢复示例
shell控制与恢复告警次数的实现代码
监测linux系统负载与CPU、内存、硬盘、用户数的shell脚本
shell磁盘监控及报警的脚本
ping检测告警函数的shell脚本
监控硬盘空间使用率的shell脚本(图文)
Open-Falcon 如何实现自定义多功能告警
监控Linux系统内存的shell脚本(图文)
mysqldump使用binlog二进制日志进行备份的例子
如何在生产环境mysql删除亿万级数据解并且不影响数据库主从延迟的解决方案

[关闭]
~ ~