python: logging日志級別詳解


import logging

'''
日志級別:
critical > error > warning > info > debug,notset
級別越高打印的日志越少,反之亦然,即
debug    : 打印全部的日志(notset等同於debug)
info     : 打印info,warning,error,critical級別的日志
warning  : 打印warning,error,critical級別的日志
error    : 打印error,critical級別的日志
critical : 打印critical級別
'''

handler=logging.FileHandler("/tmp/TNLOG-error.log")

def log(level):
    logger = logging.getLogger()
    #不能重復創建handler,否則會重復寫入同樣的記錄?
    logger.addHandler(handler)
    logger.setLevel(level)
    logger.debug("debug")
    logger.info("info")
    logger.warning("warning")
    logger.error("error")
    logger.critical("critical\n")

if __name__ == "__main__":
    log(logging.NOTSET)
    log(logging.DEBUG)
    log(logging.INFO)
    log(logging.WARNING)
    log(logging.ERROR)
    log(logging.CRITICAL)

在程序開發階段,顯然我們需要大量的日志,因此日志級別應為debug,等系統逐漸穩定,我們需要記錄的日志應該減少一些,這樣可以提高程序執行效率(我覺得似乎不應該刪除debug級別的日志語句,因為維護時會再度需要?雖然讓代碼變長,我認為好的系統應該有這樣的語句在)這個時候,我們更關心用戶在系統里的動作,用戶做了什么,如果我們的程序是一個可以買東西的網站,我們需要記錄一切與錢有關的信息,即用戶對於核心數據的修改,我們必須記錄在案,這個時候我們可以選擇info和info以上級別的日志,最重要的信息,顯然我們需要選擇critical級別,具體怎么划分看系統的設計,我也沒有太多經驗就先不說了,不過異常部分(try-except)我建議還是使用error級別,即使系統正常運行以后也不能保證有未預料的錯誤產生,一旦選擇低級別的日志很可能會漏記重要的系統異常的原因


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM