设为首页 收藏本站
查看: 677|回复: 0

nagios-plugin(log)

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-9-28 09:19:22 | 显示全部楼层 |阅读模式
#!/usr/bin/env python

import datetime
import re
import sys

REG_SYSLOG = re.compile(r'(?P<logtime>\w+ \d+ [\d:]+) (?P<hostname>[\d\w.]+) (?P<progname>\w+)(\[\d*\])?: (?P<msg>.*)')

DELTA = datetime.timedelta(minutes=3)

MONTH_MAPPING = {"Jan":1,"Feb":2,"Mar":3,"Apr":4,"May":5,"Jun":6,"Jul":7,"Aug":8,"Sep":9,"Oct":10,"Nov":11,"Dec":12}

PROG_COUNTER = {}
KEYWORD_COUNTER = {}

KEYWORD = ['error','fatal']

def parsertime(s):
    month, day, t = s.split()
    hour, minute, second = [int(i) for i in t.split(':')]
    return datetime.datetime(2014,MONTH_MAPPING[month],int(day),hour,minute,second)

def count(metric, counter):
    if metric in counter:
        counter[metric] += 1
    else:
        counter[metric] = 1

def getMessages():
    starttime = datetime.datetime.now() - DELTA
    logfile = '/var/log/messages'
    with open(logfile) as fd:
        for line in fd:
            logmatch = REG_SYSLOG.match(line)
            if logmatch:
                logdict = logmatch.groupdict()
                logtime = parsertime(logdict['logtime'])
                if logtime >= starttime:
                    count(logdict['progname'], PROG_COUNTER)
                    for k in KEYWORD:
                        if k in logdict['msg'].lower():
                            count(k, KEYWORD_COUNTER)

def print_msgs(status,msgs):
    mapping = {0:'OK',1:'Warning',2:'Critcal',3:'Unknown'}
    msg = '%s:%s' % (mapping[status],' | '.join(msgs))
    print msg
    sys.exit(status)

def check_counter():
    msgs = []
    status = 0
    if PROG_COUNTER:
        for c in PROG_COUNTER:
            if PROG_COUNTER[c] > 2:
                msgs.append("prog %s has reached %s " % ( c, PROG_COUNTER[c]))
                status = 2
            elif PROG_COUNTER[c] <= 2:
                msgs.append("prog %s has reached %s " % ( c, PROG_COUNTER[c]))
                status = 1
    if KEYWORD_COUNTER:
        status = 2
        msgs.append("keywords have reached %s" % ','.join(['%s:%s'%(k,KEYWORD_COUNTER[k]) for k in KEYWORD_COUNTER]))
    print_msgs(status, msgs)

if __name__ == '__main__':
    getMessages()
    check_counter()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-25434-1-1.html 上篇帖子: nagios+centreon总结之第八章——Centreon 添加nagios检查命令 下篇帖子: nagios-plugin(mem)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表