shell寫的警示次數控制及恢複範例程式碼
來源:互聯網
上載者:User
俺也是新手,寫的有點老土,權當練手了,供初學的朋友們參考吧。
複製代碼 代碼如下:#!/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