這個月我們連續增加了4台國外伺服器,讓每台伺服器的負載更低一些,這樣網民和搜尋引擎通路更順暢,利于流量和廣告收入的提升。
我今年早幾個月曾經在網上找了一段檢測Ping的代碼,稍微改了一下适應我們的需要,已經用了幾個月,極少數遇到某伺服器ping不通的情況也得到了報警通知。今天又找出來加了一些新伺服器的IP和域名,并在程式中加了一些注釋,checkping.sh程式如下:
#!/bin/sh
####################
#伺服器ping測試程式
#James Qi 2013
#循環檢測各台伺服器,在指定的ping次數中丢失的必須小于某個設定值,如果大于則說明有問題,發郵件通知報警
#在/etc/crontab中設定本程式的執行周期
####################
#
#參數設定
COUNT=100 #每台伺服器測試ping的次數
MAX=90 #其中最多無法ping通的次數
HOST=(#伺服器清單,IP位址或者域名
219.140.x.x
219.140.xx.xx
219.140.xxx.xxx
falcon000.startdedicated.com
eagle000.startdedicated.com
hawk000.startdedicated.com
)
#循環檢測
for ipadd in "${HOST[@]}"
do
timing=`date +%Y/%m/%d/%H:%M:%S`
ping $ipadd -c $COUNT > 1ping.log
losspag=`grep "packet loss" 1ping.log |awk '{print $6}' |sed 's/%//g'`
if [ $losspag -ge $MAX ] ;
then
echo $timing > tmp.log
echo -n $ipadd >> tmp.log
echo -n "packet loss is more than $MAX of $COUNT">> tmp.log
cat /root/tmp.log | mail -s "$ipadd ping packet loss is more then $MAX of $COUNT" [email protected]
else
rm -f tmp.log
fi
done
在/etc/crontab中設定:
*/6 * * * * root sh /root/checkping.sh &
也就是每6分鐘執行checkping.sh一次。
這個能對伺服器的監控起到一定作用。注意有時國内到國外的線路很差,也會造成報警,我加大了ping的次數到100、最多可以丢失90次來盡量消除短暫的網絡不穩帶來的影響,也可以在國外某台伺服器上單獨運作一個這個程式來專門檢測國外伺服器群。