• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

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

    发布者: 涵韵 | 发布时间: 2025-6-17 08:12| 查看数: 174| 评论数: 0|帖子模式

    python logging模块及日志定时清理


    1.创建logger对象
    1. logger = logging.getLogger(log_name) # 传入logger名字
    复制代码
    2.logging.basicConfig常用样式
    1. logging.basicConfig(level=logging.DEBUG,
    2.                     format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
    3.                     datefmt='%a, %d %b %Y %H:%M:%S',
    4.                     filename='./Log/test_log.log',
    5.                     filemode='a')
    复制代码
    参数名称描述level日志输出级别format日志输出的格式datefmt使用指定的格式字符串的处理程序filename日志输出到文件的文件名filemode文件模式,r[+]、w[+]、a[+]日志等级说明:

      1. DEBUG
      复制代码
      :程序调试bug时使用
      1. INFO
      复制代码
      :程序正常运行时使用
      1. WARNING
      复制代码
      :程序未按预期运行时使用,但并不是错误,如:用户登录密码错误
      1. ERROR
      复制代码
      :程序出错误时使用,如:IO操作失败
      1. CRITICAL
      复制代码
      :特别严重的问题,导致程序不能再继续运行时使用,如:磁盘空间为空,一般很少使用
    日志等级从低到高的顺序是: DEBUG < INFO < WARNING < ERROR < CRITICAL

    3.常用handlers的使用


    StreamHandler

    流handler——包含在logging模块中的三个handler之一。
    能够将日志信息输出到sys.stdout, sys.stderr 或者类文件对象(更确切点,就是能够支持write()和flush()方法的对象)。
    只有一个参数:
    1. class logging.StreamHandler(stream=None)
    复制代码
    日志信息会输出到指定的stream中,如果stream为空则默认输出到sys.stderr。

    FileHandler

    logging模块自带的三个handler之一。继承自StreamHandler。将日志信息输出到磁盘文件上。
    构造参数:
    1. 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相同:
    1. class logging.handlers.WatchedFileHandler(filename, mode='a', encoding=None, delay=False)
    复制代码
    RotatingFileHandler

    位于logging.handlers支持循环日志文件。
    1. 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,支持定时生成新日志文件。
    1. 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参数配置

    如:
    1. class logging.handlers.TimedRotatingFileHandler(filename, when='h', interval=1, backupCount=0, encoding=None, delay=False, utc=False)
    复制代码

      1. when
      复制代码
      :是一个字符串,用于描述滚动周期的基本单位,字符串的值及意义如下(不区分大小写):
    类型单位S秒M分H时D天W0-W6周一至周日midnight每天的凌晨

      1. interval
      复制代码
      : 滚动周期,单位有when指定,比如:when=’D’,interval=1,表示每天产生一个日志文件,且清理匹配到的过期文件;
      1. backupCount
      复制代码
      : 表示日志文件的保留个数;
      1. delay
      复制代码
      :延迟文件创建,直到第一次调用emit()方法创建日志文件
      1. atTime
      复制代码
      :在指定的时间(datetime.time格式)创建日志文件。
    删除日志文件设置
    1. # suffix设置,会生成文件名为xxx.2022-02-10.log
    2. log_file_handler.suffix = "%Y-%m-%d.log"  
    3. # extMatch是编译好正则表达式,用于匹配日志文件名后缀,需要注意的是suffix和extMatch一定要匹配的上,如果不匹配,过期日志不会被删除。
    4. log_file_handler.extMatch = re.compile(r"^\d{4}-\d{2}-\d{2}.log$")
    复制代码
    suffix和extMatch的格式要相对应,Year-4位,m-2位 以此类推
    举例:
    1. rf_handler = logging.handlers.TimedRotatingFileHandler('all.log', when='midnight', interval=1, backupCount=7, atTime=datetime.time(0, 0, 0, 0))
    2. 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__________"))
    复制代码
    添加到日志处理对象集合
    1. my_logging.addHandler(handle)
    复制代码
    关闭日志收集器
    1. my_logging.removeHandler(handler)
    复制代码
    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

    来源:https://www.jb51.net/python/339741fqs.htm
    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

    最新评论

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表