Python logging日志库空间不足问题解决
项目中使用的日志库是使用python官方库logging封装的,但是居然一直么有设置日志自动滚动,经常会受到告警说哪台机器磁盘空间又满,清理一下,于是研究一下,解决这个问题。
参考:https://docs.python.org/2/library/logging.handlers.html
TimedRotatingFileHandler有三个参数很关键
when、interval、backupCount
when指定滚动依据的单位,可选的有天、小时、分钟、秒等;interval指定间隔多少个when之后滚动日志;而backupCount指定最多保留多少个日志。
所以结合这三个参数就可以实现我要的目的了,让日志随时间滚动,同时限制总的日志个数。
demo:
#!/usr/bin/envpython
#-*-coding:utf-8-*-
importsys
importos
importtime
importlogging
importlogging.handlers
if__name__=='__main__':
iflen(sys.argv)!=2:
print('Usage:%slog_name'%(sys.argv[0]))
sys.exit(0)
log_dir='./log'
log_name=sys.argv[1]
logger=logging.getLogger(log_name)
logger.setLevel(logging.DEBUG)
#inithandler
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)
whileTrue:
time.sleep(1)
logger.info('Helloworld%s'%(time.strftime("%Y/%M/%d-%H:%m:%S")))
结果:
可以看到最上面的一条记录记录就被滚掉了。
666
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。