<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)維也需要開(kāi)發(fā)相應(yīng)的腳本進(jìn)行支持。一般監(jiān)控有變更都需要通知運(yùn)維人員來(lái)操作,我們也可以自己開(kā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 閱讀(677) 評(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ā)編程

    開(kāi)源技術(shù)

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

    搜索

    •  

    積分與排名

    • 積分 - 359964
    • 排名 - 154

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    主站蜘蛛池模板: 亚洲 欧洲 视频 伦小说| 国产又长又粗又爽免费视频 | 亚洲欧洲日韩综合| 手机看片国产免费永久| 国产亚洲精品免费视频播放| 污视频网站免费观看| 免费国产精品视频| 一个人看的免费观看日本视频www| 亚洲AV无码乱码在线观看牲色| 美女黄色毛片免费看| 亚洲欧美国产日韩av野草社区| 免费电影在线观看网站| 国产精品亚洲一区二区麻豆| 免费av欧美国产在钱| 亚洲av色香蕉一区二区三区| 免费国产a国产片高清| 国产精品高清免费网站| 国产AV无码专区亚洲AV毛网站| 永久免费AV无码网站国产| 内射少妇36P亚洲区| 男人的好看免费观看在线视频| 亚洲色欲色欲www在线播放| 免费一看一级毛片| 中文字幕免费人成乱码中国| 亚洲国产一区二区三区青草影视| 免费观看无遮挡www的视频| 亚洲一线产品二线产品| 免费在线观看亚洲| 无码一区二区三区免费| 亚洲中文无码卡通动漫野外| 亚洲国产精品无码久久九九| 久久国产免费一区| 亚洲伊人久久大香线蕉AV| 最新精品亚洲成a人在线观看| 一区二区免费视频| 亚洲精华国产精华精华液| 毛茸茸bbw亚洲人| 亚洲一区二区三区免费在线观看| 欧美色欧美亚洲另类二区| 亚洲AV无码专区国产乱码电影 | 四虎影院免费在线播放|