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:
- Loggers 提供應(yīng)用程序代碼直接使用的接口。
- Filters 提供粒度更好的工具用于決定輸出哪些日志記錄。
- Handlers 發(fā)送日志記錄(由loggers創(chuàng)建)到正確的目標(biāo)。
- 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