PythonのロギングハンドラでsetLevelのポイントは何ですか?
質問
例えば、以下のようなコードがあるとします。
import logging
import logging.handlers
a = logging.getLogger('myapp')
h = logging.handlers.RotatingFileHandler('foo.log')
h.setLevel(logging.DEBUG)
a.addHandler(h)
# The effective log level is still logging.WARN
print a.getEffectiveLevel()
a.debug('foo message')
a.warn('warning message')
を設定することが期待されます。
logging.DEBUG
を設定することで、デバッグレベルのメッセージがログファイルに書き込まれることを期待します。しかし、これは有効なレベル (例えば
logging.WARNING
と等しい)、ログに記録されるのは
warn
メッセージのみをログファイルに記録し、デバッグメッセージは記録しません。
ハンドラのログ レベルは床に落とされているように見えますが、たとえば黙って無視されています。そこで疑問に思うのですが、なぜ
setLevel
をつける必要があるのでしょうか?
どのように解決するのですか?
より細かい制御が可能になります。デフォルトでは、ルートロガーは
WARNING
レベルが設定されています。これは、より低いレベルのメッセージを表示しないことを意味します (ハンドラのレベルがどのように設定されているかに関係なく!)。しかし、もしルートロガーのレベルを
DEBUG
に設定すると、確かにメッセージはログファイルに送信されます。
import logging
import logging.handlers
a = logging.getLogger('myapp')
a.setLevel(logging.DEBUG) # set root's level
h = logging.handlers.RotatingFileHandler('foo.log')
h.setLevel(logging.DEBUG)
a.addHandler(h)
print a.getEffectiveLevel()
a.debug('foo message')
a.warn('warning message')
さて、デバッグ情報を記録しない新しいハンドラを追加したい場合を想像してください。 これは、ハンドラのロギングレベルを設定することで実現できます。
import logging
import logging.handlers
a = logging.getLogger('myapp')
a.setLevel(logging.DEBUG) # set root's level
h = logging.handlers.RotatingFileHandler('foo.log')
h.setLevel(logging.DEBUG)
a.addHandler(h)
h2 = logging.handlers.RotatingFileHandler('foo2.log')
h2.setLevel(logging.WARNING)
a.addHandler(h2)
print a.getEffectiveLevel()
a.debug('foo message')
a.warn('warning message')
さて、ログファイル
foo.log
には両方のメッセージが含まれ、一方、ファイル
foo2.log
には警告メッセージだけが含まれます。エラーレベルメッセージのみのログファイルに興味がある場合は、 単に
Handler
を追加し、そのレベルを
logging.ERROR
を使用し、すべて同じ
Logger
.
を思い浮かべるかもしれません。
Logger
ロギングレベルは、与えられたロガーに対してどのメッセージが "興味深いものであるかについてのグローバルな制限として考えることができます。
とそのハンドラ
. ロガーによって考慮されるメッセージは
以後
はハンドラに送られ、ハンドラは独自のフィルタリングとロギング処理を実行します。
関連
-
[解決済み] Pythonで現在時刻を取得する方法
-
[解決済み] Pythonのリストメソッドであるappendとextendの違いは何ですか?
-
[解決済み] Python 3 の "python -m SimpleHTTPServer" に相当するものは何ですか?
-
[解決済み] Pythonの "assert "はどのように使うのですか?
-
[解決済み】ネストされたディレクトリを安全に作成するには?
-
[解決済み】__str__と__repr__の違いは何ですか?
-
[解決済み] Python Logging - インポートモジュールからのロギングを無効にする
-
[解決済み] 値で列挙名を取得する [重複]。
-
[解決済み] スペースがないテキストを単語のリストに分割する方法
-
[解決済み] pipの依存性/必要条件をリストアップする方法はありますか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] Pythonのキャッシュライブラリはありますか?
-
[解決済み] Pythonのインスタンス変数とクラス変数
-
[解決済み] Pythonのargparseを使った隠し引数の作成
-
[解決済み] PythonからSMTPを使用してメールを送信する
-
[解決済み] 文字列のリストを内容に基づいてフィルタリングする
-
[解決済み] サブフォルダからのインポートモジュール
-
[解決済み] 異なる順序で同じ要素を持つ2つのJSONオブジェクトを等しく比較するには?
-
[解決済み] Pythonでファイルの読み込みと上書きをする
-
[解決済み] Pythonの辞書にあるスレッドセーフについて
-
[解決済み] Pythonでリストが空かどうかをチェックする方法は?重複