<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 167,  comments - 30,  trackbacks - 0

    企業(yè)中對(duì)于服務(wù)器常規(guī)監(jiān)控都有部署監(jiān)控軟件系統(tǒng),如常用的zabbix、ganglia、nagios、observer等,但是對(duì)于特殊的業(yè)務(wù)監(jiān)控,比如日志中出現(xiàn)某些關(guān)鍵字多少次后即報(bào)警通知負(fù)責(zé)人,對(duì)某些Http接口心跳監(jiān)控或結(jié)果正確性檢測(cè)等,這些特定需求運(yùn)維也需要開發(fā)相應(yīng)的腳本進(jìn)行支持。一般監(jiān)控有變更都需要通知運(yùn)維人員來(lái)操作,我們也可以自己開發(fā)腳本實(shí)現(xiàn)簡(jiǎn)單的監(jiān)控。


    import
     smtplib
    import socket
    import fcntl
    import struct
    import os 
    import commands
    import time

    from email.mime.text import MIMEText

    # 發(fā)送的郵件列表,多個(gè)郵件地址逗號(hào)分隔
    mailto_list=[
          'david1228@foxmail.com',
    ]

    # 需要監(jiān)控列表,JSON格式配置
    #
     配置說(shuō)明:logfile需要檢測(cè)的日志文件,limitnum為閥值,readnum為讀取日志最后的行數(shù),kword為出現(xiàn)的關(guān)鍵字,sg為大于或小于閥值滿足后報(bào)警
    check_list={
    'mq:geturl_updatevideo:flush cache OK has a problem, please check!' : {
        'logfile':'/home/ldw/logs/geturl/online/geturl_updatevideo.log',
        'limitnum':'10',
        'readnum':'200',
        'kword':'flush cache OK',
        'sg':'<'
    },
    'mq:geturl_updatevideo has message error, please check!' : {
        'logfile':'/home/ldw/logs/geturl/online/geturl_updatevideo.log',
        'limitnum':'1',
        'readnum':'2000',
        'kword':'message error',
        'sg':'<'
    }
    }

    # 讀取網(wǎng)卡IP,輸入?yún)?shù)為網(wǎng)卡名,如eth0、eth1、bond0(網(wǎng)卡做Bond)
    def get_ip_address(ifname):
        s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        return socket.inet_ntoa(fcntl.ioctl(
            s.fileno(),
            0x8915,  # SIOCGIFADDR
            struct.pack('256s', ifname[:15])
        )[20:24])

    # 郵件發(fā)送
    def send_mail(to_list,sub,content):
        print content
        me=mail_user
        # 發(fā)送中文,需要設(shè)置編碼
        msg = MIMEText(content,_subtype='plain',_charset='gb2312')
        msg['Subject'] = sub
        msg['From'] = me
        msg['To'] = ";".join(to_list)
        try:
            server = smtplib.SMTP()
            server.connect(mail_host)
            server.login(mail_user,mail_pass)
            server.sendmail(me, to_list, msg.as_string())
            server.close()
            return True
        except Exception, e:
            print str(e)
            return False

    # 發(fā)送郵箱認(rèn)證配置
    mail_host="smtp.126.com"
    mail_user="xyz@126.com"
    mail_pass="xyz"
    mail_postfix="126.com"

    content = ""
    timeddiff=300
    def monitor_list(ethip):
        for k in check_list.keys():
            logfile=check_list[k]['logfile']
            readnum=check_list[k]['readnum']
            limitnum=check_list[k]['limitnum']
            kword = check_list[k]['kword']
            sg = check_list[k]['sg']
            
            # 需要監(jiān)控的文件小于5分鐘進(jìn)行檢測(cè)
            if ( os.path.exists(logfile) and (time.time() - os.stat(logfile).st_mtime) < timeddiff ):
                cmdstring='tail -n ' + readnum + ' ' + logfile + ' |  grep "'+ kword+'" |wc -l 2>&1'
                cmdstatus,cmdoutput = commands.getstatusoutput(cmdstring)
                if ((sg == '<' and int(cmdoutput) < int(limitnum)) or (sg == '>' and int(cmdoutput) > int(limitnum))):
                    # 郵件正文,帶上有問(wèn)題的服務(wù)器IP,方便定位.
                    content = ethip +k+":  "+cmdoutput+"/"+readnum+"\n"
                    send_mail(mailto_list,"Monitor Warning!!!",content)
                    content = ""
                else:
                    print " Normal monitoring service:"+logfile
            else:
                print " File has not been updated : "+logfile

    if __name__ == '__main__':
        ethip = "["+get_ip_address('bond0')+"]\n"+content
        monitor_list(ethip)
    posted on 2015-10-31 12:37 David1228 閱讀(669) 評(píng)論(0)  編輯  收藏 所屬分類: 動(dòng)態(tài)語(yǔ)言Python

    <2015年10月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(4)

    隨筆分類

    隨筆檔案

    文章檔案

    新聞分類

    新聞檔案

    相冊(cè)

    收藏夾

    Java

    Linux知識(shí)相關(guān)

    Spring相關(guān)

    云計(jì)算/Linux/虛擬化技術(shù)/

    友情博客

    多線程并發(fā)編程

    開源技術(shù)

    持久層技術(shù)相關(guān)

    搜索

    •  

    積分與排名

    • 積分 - 358616
    • 排名 - 154

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: jizz免费观看| 亚洲成a人片7777| 亚洲精品国产V片在线观看| 看全色黄大色大片免费久久| 成人免费毛片视频| 免费无码不卡视频在线观看| 暖暖免费高清日本中文| 四虎在线视频免费观看| 国产大片免费观看中文字幕| 日本19禁啪啪无遮挡免费动图| 国产又粗又猛又爽又黄的免费视频| 午夜两性色视频免费网站| 国产成人免费手机在线观看视频| 国产jizzjizz免费看jizz| 亚洲国产成人久久综合一区77| 亚洲成av人片在线观看天堂无码| 亚洲国产一区二区三区| 久久久久国产亚洲AV麻豆| 国产亚洲成av片在线观看| 亚洲尹人九九大色香蕉网站| 亚洲精品免费在线| 亚洲精品综合在线影院| 爱情岛亚洲论坛在线观看| 特级毛片在线大全免费播放| 成人妇女免费播放久久久| 亚洲免费视频网站| 国产桃色在线成免费视频| 国产成人精品男人免费| 精品国产人成亚洲区| 亚洲精品视频在线| 亚洲人精品亚洲人成在线| 美女免费精品高清毛片在线视| 老司机精品免费视频| 久草视频在线免费| 国产一区二区三区免费看| 亚洲女久久久噜噜噜熟女| 亚洲国产av高清无码| 美女视频免费看一区二区| 在线观看肉片AV网站免费| 日韩免费一区二区三区在线播放| 免费一看一级毛片人|