27.2. faulthandler
--- Python tracebackのダンプ¶
バージョン 3.3 で追加.
このモジュールは、例外発生時、タイムアウト時、ユーザシグナルの発生時などのタイミングでpython tracebackを明示的にダンプするための関数を含んでいます。これらのシグナル、SIGSEGV
、SIGFPE
、SIGABRT
、SIGBUS
、SIGILL
に対するフォールトハンドラをインストールするには faulthandler.enable()
を実行してください。python起動時に有効にするには環境変数 PYTHONFAULTHANDLER
を設定するか、コマンドライン引数に -X
faulthandler
を指定してください。
Pythonのフォールトハンドラは、apportやWindowsのフォールトハンドラのようなシステムフォールトハンドラと互換性があります。このモジュールは sigaltstack()
関数が使用可能であればシグナルハンドラ用に代替スタックを利用します。これによってスタックオーバーフロー時にもスタックトレースを出力することができます。
フォールトハンドラは絶望的なケースで呼び出されます。そのためシグナルセーフな関数しか使うことができません (例: ヒープメモリ上にメモリ確保はできません)。この制限により、tracebackのダンプ機能は通常のPythonのtracebackと比べてごく僅かなものです:
- ASCIIのみサポートされます。エンコード時には
backslashreplace
エラーハンドラを使用します。 - すべての文字列は500文字以内に制限されています。
- ファイル名、関数名、行数のみ表示します。(ソースコードの表示はありません)
- 100フレーム、100スレッドに制限されています。
- 順番は保持されます: 最新の呼び出しが最初に表示されます。
デフォルトでは、Pythonのtracebackは sys.stderr
に書き出されます。tracebackを見るには、対象アプリケーションはターミナル上で実行しなければなりません。 faulthandler.enable()
に渡す引数によってログファイルを指定することができます。
モジュールはC言語で実装されているので、アプリのクラッシュ時でもPythonがデッドロックした場合でもダンプができます。
27.2.1. tracebackのダンプ¶
-
faulthandler.
dump_traceback
(file=sys.stderr, all_threads=True)¶ 全スレッドのtracebackを file へダンプします。もし all_threads が
False
であれば、現在のスレッドのみダンプします。バージョン 3.5 で変更: Added support for passing file descriptor to this function.
27.2.2. フォールトハンドラの状態¶
-
faulthandler.
enable
(file=sys.stderr, all_threads=True)¶ フォールトハンドラを有効にします。
SIGSEGV
、SIGFPE
、SIGABRT
、SIGBUS
、SIGILL
シグナルに対して Pythonのtracebackをダンプするハンドラをインストールします。もし all_threads がTrue
であれば、すべての実行中のスレッドについてtracebackをダンプします。そうでなければ現在のスレッドのみダンプします。The file must be kept open until the fault handler is disabled: see issue with file descriptors.
バージョン 3.5 で変更: Added support for passing file descriptor to this function.
-
faulthandler.
is_enabled
()¶ フォールトハンドラが有効かどうかチェックします。
27.2.3. タイムアウト後にtracebackをダンプする¶
-
faulthandler.
dump_traceback_later
(timeout, repeat=False, file=sys.stderr, exit=False)¶ timeout 秒経過後か、repeat が
True
の場合は timeout 秒おきに全スレッドの traceback をダンプします。もし exit がTrue
であればtracebackをダンプした後、status=1で_exit()
を呼び出します。(注:_exit()
を呼び出すとプロセスを即座に終了します。つまりファイルバッファのクリアといった終了処理を行いません。)関数が2回呼ばれた場合、最新の呼び出しが前回の呼び出しパラメータを引き継いでタイムアウト時間をリセットします。タイマーの分解能は1秒未満です。The file must be kept open until the traceback is dumped or
cancel_dump_traceback_later()
is called: see issue with file descriptors.この関数は番犬(watchdog)スレッドを使って実装されているため、Pythonがスレッド無効でコンパイルされている場合は利用できません。
バージョン 3.5 で変更: Added support for passing file descriptor to this function.
-
faulthandler.
cancel_dump_traceback_later
()¶ dump_traceback_later()
の最新の呼び出しをキャンセルします。
27.2.4. ユーザシグナルに対してtracebackをダンプする¶
-
faulthandler.
register
(signum, file=sys.stderr, all_threads=True, chain=False)¶ ユーザシグナルを登録します: すべてのスレッドでtracebackをダンプするために signum シグナルをインストールします。ただし all_threads が
False
であれば現在のスレッドのみ file にダンプします。もし chain がTrue
であれば以前のハンドラも呼び出します。The file must be kept open until the signal is unregistered by
unregister()
: see issue with file descriptors.Windowsでは利用不可です。
バージョン 3.5 で変更: Added support for passing file descriptor to this function.
-
faulthandler.
unregister
(signum)¶ ユーザシグナルを登録解除します:
register()
でインストールした signum シグナルハンドラをアンインストールします。シグナルが登録された場合はTrue
を返し、そうでなければFalse
を返します。Windowsでは利用不可です。
27.2.5. ファイル記述子の問題¶
enable()
、dump_traceback_later()
ならびに register()
は引数 file に渡されたファイル記述子を保持します。ファイルが閉じられファイル記述子が新しいファイルで再利用された場合や、os.dup2()
の使用でファイル記述子が置き換えた場合、 traceback の結果は別のファイルへ書き込まれます。ファイルが置き換えられた場合は、毎回これらの関数を呼び出しなおしてください。
27.2.6. 使用例¶
Example of a segmentation fault on Linux with and without enabling the fault handler:
$ python3 -c "import ctypes; ctypes.string_at(0)"
Segmentation fault
$ python3 -q -X faulthandler
>>> import ctypes
>>> ctypes.string_at(0)
Fatal Python error: Segmentation fault
Current thread 0x00007fb899f39700 (most recent call first):
File "/home/python/cpython/Lib/ctypes/__init__.py", line 486 in string_at
File "<stdin>", line 1 in <module>
Segmentation fault