logging

logging 簡(jiǎn)介:

  • logging 函數(shù)根據(jù)它們用來(lái)跟蹤的事件的級(jí)別或嚴(yán)重程度來(lái)命名:
級(jí)別 何時(shí)使用
DEBUG 詳細(xì)信息,調(diào)試問(wèn)題時(shí)會(huì)感興趣。
INFO 事情按預(yù)期工作。
WARNING 發(fā)生了一些意外,或者不久的將來(lái)會(huì)發(fā)生問(wèn)題(如‘磁盤(pán)滿了’)。軟件還是在正常工作。
ERROR 更嚴(yán)重的問(wèn)題,軟件已不能執(zhí)行一些功能了。
CRITICAL 嚴(yán)重錯(cuò)誤,表明軟件已不能繼續(xù)運(yùn)行了。
  • logging 模塊提供 logger,handler,filter,formatter:
    1. Loggers 提供應(yīng)用程序代碼直接使用的接口。
    2. Filters 提供粒度更好的工具用于決定輸出哪些日志記錄。
    3. Handlers 發(fā)送日志記錄(由loggers創(chuàng)建)到正確的目標(biāo)。
    4. Formatters 指出最終輸出中的日志記錄的格式。
  • logging 處理流程:
logging_flow.png
  • Logger
    getLogger() 是Logger實(shí)例的引用,如果提供了名字就返回對(duì)應(yīng)名字的Logger,否則返回 root。名字是由點(diǎn)分隔的層級(jí)結(jié)構(gòu)。層級(jí)結(jié)構(gòu)中較低層級(jí)的Logger是較高層級(jí)Logger的子節(jié)點(diǎn)。例如,對(duì)于名為 foo 的Logger,記錄器 foo.bar、 foo.bar.baz
    和 foo.bam 都是 foo 的后代。
    Logger有effective level/有效級(jí)別的概念。如果一個(gè)記錄器沒(méi)有顯式地設(shè)置級(jí)別,那它父節(jié)點(diǎn)的級(jí)別被用作有效級(jí)別。root 為所有Logger的父節(jié)點(diǎn)。
    Logger.propagate 構(gòu)造函數(shù)設(shè)置該屬性為T(mén)rue
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容