当前位置: 移动技术网 > IT编程>脚本编程>Python > Python logging日志库空间不足问题解决

Python logging日志库空间不足问题解决

2020年09月15日  | 移动技术网IT编程  | 我要评论
项目中使用的日志库是使用python官方库logging封装的,但是居然一直么有设置日志自动滚动,经常会受到告警说哪台机器磁盘空间又满,清理一下,于是研究一下,解决这个问题。参考:timedrotat

项目中使用的日志库是使用python官方库logging封装的,但是居然一直么有设置日志自动滚动,经常会受到告警说哪台机器磁盘空间又满,清理一下,于是研究一下,解决这个问题。

参考:

timedrotatingfilehandler有三个参数很关键

when、interval、backupcount

when指定滚动依据的单位,可选的有天、小时、分钟、秒等;interval指定间隔多少个when之后滚动日志;而backupcount指定最多保留多少个日志。

所以结合这三个参数就可以实现我要的目的了,让日志随时间滚动,同时限制总的日志个数。

demo:

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import sys
import os
import time
import logging
import logging.handlers

if __name__ == '__main__':
  if len(sys.argv) != 2:
    print('usage:%s log_name' % (sys.argv[0]))
    sys.exit(0)

  log_dir = './log'
  log_name = sys.argv[1]
  logger = logging.getlogger(log_name)
  logger.setlevel(logging.debug)

  # init handler
  formatter = logging.formatter('%(message)s')
  file_time_handler = logging.handlers.timedrotatingfilehandler(
      os.path.join(log_dir, log_name), "m", 1, 5)
  file_time_handler.setformatter(formatter)
  file_time_handler.setlevel(logging.debug)
  logger.addhandler(file_time_handler)

  while true:
    time.sleep(1)
    logger.info('hello world %s' % (time.strftime("%y/%m/%d-%h:%m:%s")))

结果:

可以看到最上面的一条记录记录就被滚掉了。

666

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网