項目中使用的日誌庫是使用python官方庫logging封裝的,可是竟然一直麼有設置日誌自動滾動,常常會受到告警說哪臺機器磁盤空間又滿,清理一下,因而研究一下,解決這個問題。html
參考:https://docs.python.org/2/library/logging.handlers.html#logging.handlers.TimedRotatingFileHandlerpython
TimedRotatingFileHandler有三個參數很關鍵spa
when、interval、backupCount日誌
when指定滾動依據的單位,可選的有天、小時、分鐘、秒等;interval指定間隔多少個when以後滾動日誌;而backupCount指定最多保留多少個日誌。code
因此結合這三個參數就能夠實現我要的目的了,讓日誌隨時間滾動,同時限制總的日誌個數。orm
demo:htm
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")))
結果:blog
能夠看到最上面的一條記錄記錄就被滾掉了。utf-8
666get