cd mailpython
vim mail.pyvim
#!/usr/bin/env python #-*- coding: UTF-8 -*- import os,sys reload(sys) sys.setdefaultencoding('utf8') import getopt import smtplib from email.MIMEText import MIMEText from email.MIMEMultipart import MIMEMultipart from subprocess import * def sendqqmail(username,password,mailfrom,mailto,subject,content): gserver = 'smtp.qq.com' gport = 25 try: msg = MIMEText(unicode(content).encode('utf-8')) msg['from'] = mailfrom msg['to'] = mailto msg['Reply-To'] = mailfrom msg['Subject'] = subject smtp = smtplib.SMTP(gserver, gport) smtp.set_debuglevel(0) smtp.ehlo() smtp.login(username,password) smtp.sendmail(mailfrom, mailto, msg.as_string()) smtp.close() except Exception,err: print "Send mail failed. Error: %s" % err def main(): to=sys.argv[1] subject=sys.argv[2] content=sys.argv[3] ##定義QQ郵箱的帳號和密碼,你須要修改爲你本身的帳號和密碼(請不要把真實的用戶名和密碼放到網上公開,不然你會死的很慘) sendqqmail('1234567@qq.com','aaaaaaaaaa','1234567@qq.com',to,subject,content) if __name__ == "__main__": main() #####腳本使用說明###### #1. 首先定義好腳本中的郵箱帳號和密碼 #2. 腳本執行命令爲:python mail.py 目標郵箱 "郵件主題" "郵件內容"
vim mail.shspa
log=$1 t_s=`date +%s` #時間戳1 t_s2=`date -d "2 hours ago" +%s` #時間戳2(兩個小時以前的時間) #定義該時間戳的目的是保證第一次執行該腳本時v大於一小時 #由於只有發生故障的時候纔會執行該腳本,因此第一次執行必需要報警 if [ ! -f /tmp/$log ] then echo $t_s2 > /tmp/$log fi #建立記錄時間戳的日誌文件 t_s2=`tail -1 /tmp/$log|awk '{print $1}'` echo $t_s>>/tmp/$log v=$[$t_s-$t_s2] #兩個時間戳的間隔時間 echo $v #計時器: if [ $v -gt 3600 ] then #若是時間間隔大於3600s,則啓動報警系統 ./mail.py $1 $2 $3 echo "0" > /tmp/$log.txt #$log.txt爲計數器文件: else if [ ! -f /tmp/$log.txt ] then echo "0" > /tmp/$log.txt fi #查看計數器文件中的數字 nu=`cat /tmp/$log.txt` nu2=$[$nu+1] echo $nu2>/tmp/$log.txt #重置$log.txt數值 if [ $nu2 -gt 10 ] then #告警收斂:該故障持續十分鐘,開始報警 ./mail.py $1 "trouble continue 10 min $2" "$3" echo "0" > /tmp/$log.txt #告警結束後從新開始計數 fi fi
將告警任務寫入計劃任務中,每分鐘執行一次debug
crontab -e * * * * * cd /usr/local/sbin/mon/bin ; bahs main.sh
手動執行腳本日誌
查看日誌code
不須要監控502server
暫時不須要寫入日誌crontab
執行腳本ip