一、shell腳本
- 監控腳本
iplist=./ip
stime=100
log=/var/log/jiankong.log
uplog=/var/log/jiankongup.log
downlog=/var/log/jiankongdown.log
while true ;do
while read ip ;do
if [[ $ip =~ [0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3} ]];then
#{
if ping -c1 -w1 $ip &> /dev/null ;then
echo "$ip [ up ]" >> $uplog
else
echo "`date '+%F %T'----`$ip [ down ]" >> $downlog
echo "$ip [ down ]" | mail -s "ERROR " root
fi
#}&
else
echo -e "\033[31mError\033[0m : iplist file `grep -n $ip $iplist`" >> $downlog
fi
done <$iplist
sleep 10
done
- 服務器IP列表腳本
[root@centos7 jiankong]$vim jiankong
10.0.0.7
10.0.0.6
10.0.0.16
10.0.0.56
10.0.0.57
172.18.252.235
172.18.253.42
172.18.253.199
10.0.0.100
二、腳本解析
#服務器IP列表文件
iplist=./ip
#檢測間隔
stime=100
#總日志文件
log=/var/log/jiankong.log
#網絡無異常日志文件
uplog=/var/log/jiankongup.log
#網絡異常日志文件
downlog=/var/log/jiankongdown.log
#最外層為死循環,讓此腳本一直運行不退出。實現24小時實時監控
while true ;do
#遍歷ip列表文件中的所有ip地址
while read ip ;do
#過濾IP列表文件中的ip地址,如果有不是ip地址的行,提示錯誤。
if [[ $ip =~ [0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3} ]];then
#{....}&讓每個ping并行執行,在服務器數量龐大時提高檢測速度
{
#ping一次服務器,每次等待1秒,如果ping通則記錄到無異常日志中
if ping -c1 -w1 $ip &> /dev/null ;then
echo "$ip [ up ]" >> $uplog
#如果ping不通則記錄到異常日志文件中
else
#使用重定向,將異常服務器IP地址記錄到異常日志文件
echo "`date '+%F %T'----`$ip [ down ]" >> $downlog
#給管理員發郵件,提示有服務器網絡斷開
echo "$ip [ down ]" | mail -s "ERROR " root
fi
}&
#如果ip列表文件中IP地址有錯誤,直接提示哪行哪個IP地址寫錯。
else
echo -e "\033[31mError\033[0m : iplist file `grep -n $ip $iplist`" >> $downlog
fi
#從ip列表文件遍歷每個IP地址
done <$iplist
#每隔10秒監測一次
sleep 10
done
三、測試
-
運行腳本并讓其后臺執行
如果有服務器網絡不通,管理員會收到郵件。