日志文件报警监控脚本(可用于zabbix监控文件)测试中...

因业务要求,需要对某些日志文件中出现的关键字进行监控,所以写了个脚本用于直接用zabbix调用并返回超出阈值的监控项。

主要用来替代zabbix自带的文件监控项。可以对一台机器上的多个日志文件,多个触发阈值进行监控。不用配置多条zabbix监控项及触发器。

也许将来会逐步增加其他奇怪的监控内容

脚本代码如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Author: ColinShi

import sys, os
import datetime
import time
import re

class Log_File_Check(object):
    def __init__(self, filename, error_dict):
        self.filename = filename
        self.tmpfilename = ‘/tmp/‘+self.filename.replace(‘/‘, ‘‘) + ‘_st_size.tmp‘
        self.error_dict = error_dict
        self.res = {}
    def check_st_size(self):
        if os.path.exists(self.tmpfilename):
            with open(self.tmpfilename, ‘r‘) as f:
                pre_size = f.read()
                pre_size.replace(‘\n‘, ‘‘)
                pre_size = int(pre_size)
            if self.st_size < pre_size:
                return 0
            else:
                return self.st_size
        else:
            return 0

    def write_st_size(self):
        with open(self.tmpfilename, ‘w‘) as f:
            f.write(str(self.st_size))

    def check_content(self):
        if not os.path.exists(self.filename):
            return
        with open(self.filename, ‘r‘) as file:
            st_results = os.stat(self.filename)
            self.st_size = st_results[6]
            pre_size = self.check_st_size()
            file.seek(pre_size)
            content = file.read()
            content = content.replace(‘\n‘, ‘‘)
        for i in self.error_dict:
            pattern = re.compile(i[0])
            pattern.fullmatch()
            if int(i[1]) <= len(pattern.findall(content)):
                if self.res.get(self.filename):
                    self.res[self.filename].append(i[0])
                else:
                    self.res[self.filename] = []
                    self.res[self.filename].append(i[0])
        self.write_st_size()
        return self.res

    def start_check(self):
        return self.check_content()

def do_error_dict(filename):
    tmpdic = {}
    with open(os.path.dirname(os.path.realpath(sys.argv[0])) + ‘/‘ + filename, ‘r‘) as f:
        for i in f.readlines():
            i = i.replace(‘\n‘, ‘‘)
            i = i.split(‘||‘)
            if len(i) == 4:
                i[0] = random_time(i[0], i[-1], ‘‘)
            elif len(i) == 5:
                i[0] = random_time(i[0], i[-2], i[-1])
            if i[0] in tmpdic.keys():
                tmpdic[i[0]].append([i[1], i[2]])
            else:
                tmpdic[i[0]] = []
                tmpdic[i[0]].append([i[1], i[2]])
    return tmpdic

def random_time(filename, date_time, ex_name):
    now_time = datetime.datetime.now().strftime(date_time)
    return filename + now_time + ex_name

if __name__ == ‘__main__‘:
    ‘‘‘
    接收1个参数:
    参数一必选参数:需要监控的日志文件的list
    ‘‘‘
    result = []
    file = sys.argv[1]  # r"/tmp/logdir/odp_locic/log/rpc/rpc-request.log.wf."
    for k, v in do_error_dict(file).items():
        log_check = Log_File_Check(k, v)
        f = log_check.start_check()
        if f:
            result.append(f)
    if result == []:
        print ‘ok‘
    else:
        print ‘Threshold exceeded:‘, result  

  配置文件格式(前三个为必填参数,后两个为可选,可以同时监控多个日志文件,或者多条触发阈值报警):

一般使用:被监控文件名称||
需要匹配行的正则表达式||阈值次数
示例:
/logdir/odp_locic/log/order/order.log||^(.*)retry=0/0(.*)MQ_EXECUTE_FAILED(.*)$||10
特殊用法:文件名前缀(或者文件全名)||需要匹配行的正则表达式||阈值次数||文件特殊格式(日期时间归档)||文件后缀示例:/logdir/odp_locic/log/order/order.||^(.*)retry=0/0(.*)MQ_EXECUTE_FAILED(.*)$||10||%Y%m%d%H||.log

示例实际读取的文件为

/logdir/odp_locic/log/order/order.{当前日期小时}.log文件

备注:

这个脚本需要传入一个参数,为配置文件名称(配置文件需要和运行脚本放置在同一目录下)

该脚本只适用于linux操作系统,并且会在/tmp目录下生成相应的临时文件(日志路径+文件名_st_size.tmp),用于记录上次日志采集位置。

返回ok表示未触发阈值

返回其他表示相应的日志文件,正则表达式被触发。

原文地址:https://www.cnblogs.com/colinshi/p/10364657.html

时间: 2024-08-01 01:06:54

日志文件报警监控脚本(可用于zabbix监控文件)测试中...的相关文章

linux监控平台介绍、zabbix监控介绍、安装zabbix

linux监控平台介绍 常见开源监控软件 cacti.nagios.zabbix.smokeping.open-falcon 等等. nagios和zabbix流行度很高. cacti.smokeping 偏向于监控基础的东西. cacti可以监控网络设备,它的图形表现得非常好,非常漂亮. IDC 机房比较喜欢用cacti.smokeping,因为适合监控网络设备. cacti.nagios.zabbix 服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存

linux监控平台搭建(1)监控平台介绍、zabbix监控介绍、安装zabbix、忘记Admin密码

            (一)监控平台介绍 (二)zabbix监控介绍 (三)安装zabbix 实验需要两台机器:服务端(133)和客户端(134) 1.首先在服务端安装Zabbix的yum扩展源. 下载地址: www.zabbix.com/download wget http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix-release-3.2-1.el7.noarch.rpm 2.安装一下这个rpm包 rpm -ivh zabbix-re

Linux监控平台介绍, zabbix监控介绍,安装zabbix,忘记Admin密码如何做

Linux监控平台介绍 常见开源监控软件cacti.nagios.zabbix.smokeping.open-falcon等等 cacti.smokeping偏向于基础监控,成图非常漂亮 cacti.nagios.zabbix服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存储,nagios不用存储历史数据,注重服务或者监控项的状态,zabbix会获取服务或者监控项目的数据,会把数据记录到数据库里,从而可以成图 open-falcon为小米公司开发,开源后

六十四、Linux监控平台介绍、zabbix监控介绍、安装zabbix、忘记Admin密码如何做

一.Linux监控平台介绍 cacti.nagios.zabbix.smokeping.open-falcon等等 cacti.smokeping偏向于基础监控,成图非常漂亮 cacti.nagios.zabbix服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存储,nagios不用存储历史数据,注重服务或者监控项的状态,zabbix会获取服务或者监控项目的数据,会把数据记录到数据库里,从而可以成图. open-falcon为小米公司开发,开源后受到诸多大

Linux监控平台介绍、zabbix监控介绍、安装zabbix、忘记Admin密码如何做

19.1 Linux监控平台介绍 cacti.nagios.zabbix.smokeping.open-falcon等等 cacti.smokeping偏向基础监控,成图非常漂亮 cacti.nagios.zabbix服务端监控中心,需要PHP环境支持,其中zabbix和cacti都需要mysql作为数据存储,nagios不用存储历史数据,注重服务或者监控项的状态,zabbix会获取服务或者监控项目的数据,会把数据记录到数据库里,从而可以成图 open-falcon为小米公司开发,开源后受到诸多

Linux centosVMware Linux监控平台介绍、zabbix监控介绍、安装zabbix、忘记Admin密码如何做

一.Linux监控平台介绍 cacti.nagios.zabbix.smokeping.open-falcon等等 cacti.smokeping偏向于基础监控,成图非常漂亮 cacti.nagios.zabbix服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存储,nagios不用存储历史数据,注重服务或者监控项的状态,zabbix会获取服务或者监控项目的数据,会把数据记录到数据库里,从而可以成图 open-falcon为小米公司开发,开源后受到诸多大公

[工具开发] 把nagios监控脚本改成keepalived监控脚本

最近在做开发和办公环境的高可用,采用的是keepalived:keepalived基于Linux内核支持的LVS,既能实现高可用,又能实现负载均衡,非常实用. keepalived监控服务状态时可以用多种方式,如:HTTP_GET|SSL_GET|TCP_CHECK|SMTP_CHECK|MISC_CHECK(自定义脚本方式),为了精确的监控服务的状态,我们需要编写自定义监控脚本. 目前很多公司都会部署nagios作为服务的监控平台,nagios也需要监控脚本或者程序,如果keepalived监

linux监控平台介绍,zabbix监控介绍,zabbix安装,忘记Admin密码如何做

linux监控平台介绍 cacti.nagios.zabbix.smokeping.open-falcon等等 cacti.smokeping偏向于基础监控,成图非常漂亮 cacti.nagios.zabbix服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存储,nagios不用存储历史数据,注重服务或者监控项的状态,zabbix会获取服务或者监控项目的数据,会把数据记录到数据库里,从而可以成图 open-falcon为小米公司开发,开源后受到诸多大公司和

Linux监控平台介、zabbix监控介绍、安装zabbix、忘记Admin密码如何做

常见开源监控软件 ?cacti.nagios.zabbix.smokeping.open-falcon等等?cacti.smokeping偏向于基础监控,成图非常漂亮?cacti.nagios.zabbix服务端监控中心,需要php环境支持,其中zabbix和cacti都需要mysql作为数据存储,nagios不用存储历史数据,注重服务或者监控项的状态,zabbix会获取服务或者监控项目的数据,会把数据记录到数据库里,从而可以成图?open-falcon为小米公司开发,开源后受到诸多大公司和运维