項目中使用的日志庫是使用python官方庫logging封裝的,但是居然一直麼有設定日志自動滾動,經常會受到告警說哪台機器磁盤空間又滿,清理一下,于是研究一下,解決這個問題。
參考:https://docs.python.org/2/library/logging.handlers.html#logging.handlers.TimedRotatingFileHandler
TimedRotatingFileHandler有三個參數很關鍵
when、interval、backupCount
when指定滾動依據的機關,可選的有天、小時、分鐘、秒等;interval指定間隔多少個when之後滾動日志;而backupCount指定最多保留多少個日志。
是以結合這三個參數就可以實作我要的目的了,讓日志随時間滾動,同時限制總的日志個數。
demo:1 #!/usr/bin/env python
2 # -*- coding: utf-8 -*-
3
4 import sys
5 import os
6 import time
7 import logging
8 import logging.handlers
9
10 if __name__ == '__main__':
11 if len(sys.argv) != 2:
12 print('Usage:%s log_name' % (sys.argv[0]))
13 sys.exit(0)
14
15 log_dir = './log'
16 log_name = sys.argv[1]
17 logger = logging.getLogger(log_name)
18 logger.setLevel(logging.DEBUG)
19
20 # init handler
21 formatter = logging.Formatter('%(message)s')
22 file_time_handler = logging.handlers.TimedRotatingFileHandler(
23 os.path.join(log_dir, log_name), "M", 1, 5)
24 file_time_handler.setFormatter(formatter)
25 file_time_handler.setLevel(logging.DEBUG)
26 logger.addHandler(file_time_handler)
27
28 while True:
29 time.sleep(1)
30 logger.info('Hello world %s' % (time.strftime("%Y/%M/%d-%H:%m:%S")))
結果:
可以看到最上面的一條記錄記錄就被滾掉了。
666