Python logging日志庫空間不足問題解決
項目中使用的日志庫是使用python官方庫logging封裝的,但是居然一直么有設(shè)置日志自動滾動,經(jīng)常會受到告警說哪臺機器磁盤空間又滿,清理一下,于是研究一下,解決這個問題。
參考:https://docs.python.org/2/library/logging.handlers.html
TimedRotatingFileHandler有三個參數(shù)很關(guān)鍵
when、interval、backupCount
when指定滾動依據(jù)的單位,可選的有天、小時、分鐘、秒等;interval指定間隔多少個when之后滾動日志;而backupCount指定最多保留多少個日志。
所以結(jié)合這三個參數(shù)就可以實現(xiàn)我要的目的了,讓日志隨時間滾動,同時限制總的日志個數(shù)。
demo:
#!/usr/bin/env python# -*- coding: utf-8 -*-import sysimport osimport timeimport loggingimport logging.handlersif __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')))
結(jié)果:
可以看到最上面的一條記錄記錄就被滾掉了。
666
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. php網(wǎng)絡(luò)安全中命令執(zhí)行漏洞的產(chǎn)生及本質(zhì)探究2. 三個不常見的 HTML5 實用新特性簡介3. Angular獲取ngIf渲染的Dom元素示例4. IIS+PHP添加對webp格式圖像的支持配置方法5. ASP調(diào)用WebService轉(zhuǎn)化成JSON數(shù)據(jù),附j(luò)son.min.asp6. 無線標記語言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)第1/2頁7. 使用.net core 自帶DI框架實現(xiàn)延遲加載功能8. Warning: require(): open_basedir restriction in effect,目錄配置open_basedir報錯問題分析9. php測試程序運行速度和頁面執(zhí)行速度的代碼10. ASP.NET Core 5.0中的Host.CreateDefaultBuilder執(zhí)行過程解析
