简单脚本:需要匹配日志中的ERROR字眼,打印特定的输出结果,结合监控agent进行告警

需求是:需要实时(监控设定的时间是每分钟进行一次扫描)扫描特定的日志,匹配日志中的ERROR日志,然后输出自定义的字符串。监控agent会匹配字符串,判断是否告警。这里只分享一下脚本,监控机制有空再聊。

原先准备的python脚本:

由于环境为redhat5.9,python环境为2.4.4,所以用不了with open的方式。

#encoding:utf-8
import re


# with open('/Users/yahaha/Desktop/ums-gateway.log') as f:
#     t1 = time.time()
#     logs = f.read()
#     # print(logs)

f = None
try:
    f = open('/Users/yahaha/Desktop/ums-gateway.log')
    logs = f.read()

finally:
    if f is not None:
        f.close()

pattern = re.compile(r'ERROR')
if re.findall(pattern, logs):
    print('error')
else
    pass


shell:

#!/bin/bash

find_error(){
    log=`tail -20000 /Users/yahaha/Desktop/ums-gateway.log | grep "ERROR"`
    # echo $log
    if [ $? -ne 1 ];then
        echo "短信通道异常"
    else 
        echo "ok"
    fi
}

find_error
 

 

日志文件的量比较大,而且10分钟会被清理一次,容量保持在2G左右,所以考虑到IO消耗,和打开文件速度考虑,还是选用的了shell脚本。

监控的配置:本机上安装了监控agent,通过agent自动下发脚本,根据脚本返回的参数,设置阈值,判断是否告警。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值