python脚本编程:实时监控日志文件

本文介绍了一种使用Python实现的日志文件实时监控方法,通过循环读取并匹配关键字,适用于运维异常告警场景。该脚本能从文件头部开始读取直至最新行,并持续监控新增内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用python可以很小巧轻便的实时监控日志文件增量刷新,根据某些关键字进行匹配,方便做运维异常告警

代码

import time
import re

# specify log file path
log_path = "my.log"

# open file and monitor newst line
number = 0
position = 0

with open(log_path, mode='r') as f:
    while True:
        line = f.readline().strip()
        if line:
            number += 1
            print("[number %s] %s" % (number, line))

            # TODO: check the kewword and do sth with line

        cur_position = f.tell() # record last time file read position

        if cur_position == position:
            time.sleep(0.1) # currently no line udpated, wait a while
            continue
        else:
            position = cur_position
  • 适用于python2和python3,在python3种还可以指定读取的文件编码
  • 每次启动脚本都从头过一遍文件内容至当前的最新行,之后都会一直监控最新行
  • 可以引入正则表达式做更精准的字符串匹配和查询
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值