python: logging記錄層級詳解

來源:互聯網
上載者:User
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層級,即使系統正常運行以後也不能保證有未預料的錯誤產生,一旦選擇低層級的日誌很可能會漏記重要的系統異常的原因

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.