当前位置: 代码网 > it编程>前端脚本>Python > python logging模块详解及其日志定时清理方式

python logging模块详解及其日志定时清理方式

2025年04月16日 Python 我要评论
python logging模块及日志定时清理1.创建logger对象logger = logging.getlogger(log_name) # 传入logger名字2.logging.basicc

python logging模块及日志定时清理

1.创建logger对象

logger = logging.getlogger(log_name) # 传入logger名字

2.logging.basicconfig常用样式

logging.basicconfig(level=logging.debug,
                    format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
                    datefmt='%a, %d %b %y %h:%m:%s',
                    filename='./log/test_log.log',
                    filemode='a')
参数名称描述
level日志输出级别
format日志输出的格式
datefmt使用指定的格式字符串的处理程序
filename日志输出到文件的文件名
filemode文件模式,r[+]、w[+]、a[+]

日志等级说明:

  • debug:程序调试bug时使用
  • info:程序正常运行时使用
  • warning:程序未按预期运行时使用,但并不是错误,如:用户登录密码错误
  • error:程序出错误时使用,如:io操作失败
  • critical:特别严重的问题,导致程序不能再继续运行时使用,如:磁盘空间为空,一般很少使用

日志等级从低到高的顺序是: debug < info < warning < error < critical

3.常用handlers的使用

streamhandler

流handler——包含在logging模块中的三个handler之一。

能够将日志信息输出到sys.stdout, sys.stderr 或者类文件对象(更确切点,就是能够支持write()和flush()方法的对象)。

只有一个参数:

class logging.streamhandler(stream=none)

日志信息会输出到指定的stream中,如果stream为空则默认输出到sys.stderr。

filehandler

logging模块自带的三个handler之一。继承自streamhandler。将日志信息输出到磁盘文件上。

构造参数:

class logging.filehandler(filename, mode='a', encoding=none, delay=false)

模式默认为append,delay为true时,文件直到emit方法被执行才会打开。默认情况下,日志文件可以无限增大。

nullhandler

空操作handler,logging模块自带的三个handler之一。没有参数。

watchedfilehandler

位于logging.handlers模块中。用于监视文件的状态,如果文件被改变了,那么就关闭当前流,重新打开文件,创建一个新的流。由于newsyslog或者logrotate的使用会导致文件改变。

这个handler是专门为linux/unix系统设计的,因为在windows系统下,正在被打开的文件是不会被改变的。

参数和filehandler相同:

class logging.handlers.watchedfilehandler(filename, mode='a', encoding=none, delay=false)

rotatingfilehandler

位于logging.handlers支持循环日志文件。

class logging.handlers.rotatingfilehandler(filename, mode='a', maxbytes=0, backupcount=0, encoding=none, delay=0)

参数maxbytes和backupcount允许日志文件在达到maxbytes时rollover.当文件大小达到或者超过maxbytes时,就会新创建一个日志文件。

上述的这两个参数任一一个为0时,rollover都不会发生。也就是就文件没有maxbytes限制。backupcount是备份数目,也就是最多能有多少个备份。

当前的日志文件大小超过设定的maxbytes时会将当前的日志文件名例a.log后面加上.1的后缀,如a.log.1,并新建一个a.log文件来记录日志信息。

timedrotatingfilehandler

定时循环日志handler,位于logging.handlers,支持定时生成新日志文件。

class logging.handlers.timedrotatingfilehandler(filename, when='h', interval=1, backupcount=0, encoding=none, delay=false, utc=false)

参数when决定了时间间隔的类型,参数interval决定了多少的时间间隔。

如when=‘d’,interval=2,就是指两天的时间间隔,backupcount决定了能留几个日志文件。

超过数量就会丢弃掉老的日志文件。when的参数决定了时间间隔的类型。

其他handler

sockethandler、datagramhandler、sysloghandler、nteventhandler、smtphandler、memoryhandler、httphandler

这些handler都不怎么常用,所以具体介绍就请参考官方文档 其他handlers

handler参数配置

如:

class logging.handlers.timedrotatingfilehandler(filename, when='h', interval=1, backupcount=0, encoding=none, delay=false, utc=false)
  • when:是一个字符串,用于描述滚动周期的基本单位,字符串的值及意义如下(不区分大小写):
类型单位
s
m
h
d
w0-w6周一至周日
midnight每天的凌晨
  • interval: 滚动周期,单位有when指定,比如:when=’d’,interval=1,表示每天产生一个日志文件,且清理匹配到的过期文件;
  • backupcount: 表示日志文件的保留个数;
  • delay:延迟文件创建,直到第一次调用emit()方法创建日志文件
  • attime:在指定的时间(datetime.time格式)创建日志文件。

删除日志文件设置

# suffix设置,会生成文件名为xxx.2022-02-10.log
log_file_handler.suffix = "%y-%m-%d.log"  
# extmatch是编译好正则表达式,用于匹配日志文件名后缀,需要注意的是suffix和extmatch一定要匹配的上,如果不匹配,过期日志不会被删除。
log_file_handler.extmatch = re.compile(r"^\d{4}-\d{2}-\d{2}.log$")

suffix和extmatch的格式要相对应,year-4位,m-2位 以此类推

举例:

rf_handler = logging.handlers.timedrotatingfilehandler('all.log', when='midnight', interval=1, backupcount=7, attime=datetime.time(0, 0, 0, 0))
rf_handler.setformatter(logging.formatter("[%(asctime)s] -- %(remote_addr)s -- requested -- %(url)s -- %(levelname)s -- %(process)s -- %(thread)s -- %(module)s -- %(funcname)s -- %(lineno)d -- %(message)s --\n__________"))

添加到日志处理对象集合

my_logging.addhandler(handle)

关闭日志收集器

my_logging.removehandler(handler)

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com