python实现定时提取实时日志程序
作者:墨飏韶年 发布时间:2023-03-03 22:31:24
标签:python,提取日志
本文实例为大家分享了python定时提取实时日志的具体代码,供大家参考,具体内容如下
这是一个定时读取 实时日志文件的程序。目标文件是target_file. 它是应用程序实时写入的。
我要做的是,每个5秒钟,提取一次该日志文件中的内容,然后生成另一个文件,最后把这些文件都汇总。
#!/usr/local/bin/python
# coding:utf-8
import fileinput
import time
import os
target_file = 'user.log'
init_flag = True # 初次加载程序
time_kick = 5
record_count = 0
while True:
print '当前读到了', record_count
#没有日志文件,等待
if not os.path.exists(target_file):
print 'target_file not exist'
time.sleep(time_kick)
continue
try:
ip = '10.10.1.100'
easytime = time.strftime('%Y%m%d_%H%M%S', time.localtime())
file_name = '%s_user_%s.log' % (ip,easytime)
f_w = open(file_name, 'w')
if init_flag:
#读取整个文件
for eachline in fileinput.input(target_file):
print eachline
f_w.write(eachline)
record_count += 1
init_flag = False
else:
#如果总行数小于当前行,那么认为文件更新了,从第一行开始读。
total_count = os.popen('wc -l %s' % target_file).read().split()[0]
total_count = int(total_count)
if total_count < record_count:
record_count = 0
for eachline in fileinput.input(target_file):
line_no = fileinput.filelineno()
if line_no > record_count:
print eachline
f_w.write(eachline)
record_count += 1
f_w.close()
except:
pass
time.sleep(time_kick)
来源:https://blog.csdn.net/weixin_37887248/article/details/80727560
0
投稿
猜你喜欢
- 为了得到更好的网络,学习率通常是要调整的,即刚开始用较大的学习率来加快网络的训练,之后为了提高精确度,需要将学习率调低一点。如图所示,步长(
- 如 现有字符串 "[]aseabcd[12345]ddxabcdsx[]",要截取"abcd[" 和
- 概述见源码源码# !/usr/bin/env python# -*- coding:utf-8 -*-"""图
- 1、PHP中的抽象类PHP 5 支持抽象类和抽象方法。定义为抽象的类不能被实例化。任何一个类,如果它里面至少有一个方法是被声明为抽象的,那么
- 前言在数据分析中,分组聚合二者缺一不可。对数据聚合(求和、平均值等)通常是不可避免的。pd.agg()很方便进行聚合操作。1. 创建Data
- 某些杀毒软件会把正常的asp文件误认为是asp木马文件,而自动删除,影响正常使用。下面方法可能会有效避免被杀毒软件删除把dim t
- 1.用sqlserver的维护计划在这里我就不给截图演示了,这个比较简单,无非就是通过sqlserver自己的维护计划拖拽出2个一个‘备份数
- 首先了解一下需要的几个类所在的packagefrom torchvision import transforms, datasets as
- 在写登录功能的时候看着网上的视频学着做,然后看了源码的时候发现了一些有意思的功能,因此写这一篇笔记分享给大家.1.阅读Django自带用户系
- 每次查询分析器寻找路径时,并不会每一次都去统计索引中包含的行数,值的范围等,而是根据一定条件创建和更新这些信息后保存到数据库中,这也就是所谓
- 给浏览器绑定事件有时候是非常痛苦的事情,不同的浏览器提供不尽相同的功能的同时,也提供了不同的事件。例如,IE 系列的浏览器支持 mousee
- SELECT sch.name + '.' + t.name AS [Table Name],
- 场景现在的项目,基本都是前后端分离,后端只要提供Json等格式的数据就行。在这个背景下,模板渲染这个功能备受冷落,很少会在项目中用到。虽然在
- 在本文中,我们将学习如何使用 OpenCV 为多个图像添加水印。1. 什么是水印?水印是有意叠加在不同图像上的标志、签名、文本或图案,用于保
- 一个单独的组件注释写了一个组件 加了一些注释效果图如下分页一类的功能都已经写好了 下面就上代码,不知道有几个老哥能看的懂,有不足之处,还望老
- 前言js是一门弱类型的语言,它的强制类型转换的迷惑性也被人诟病,例如标题提到的一个小例子,我想可能很难再找到其他的语言,允许我们觉到一个值似
- 写爬虫似乎没有比用 Python 更合适了,Python 社区提供的爬虫工具多得让你眼花缭乱,各种拿来就可以直接用的 library 分分钟
- 在实际应用过程中,只要保证选项卡模块结构代码的完整性,就可以任意添加N个同类选项卡,不需要手动在HTML里绑定事件处理程序以及给要隐藏显示的
- 本文实例为大家分享了Bootstrap进度条的具体实现代码,供大家参考,具体内容如下<!doctype html><htm
- 由于初学Django所以对于其特有的表单模板和models中的filefiled并不是特别熟悉。因此在本次开发中还是依照以往自己在html中