faulthandler — Volcar el rastreo de Python

Nuevo en la versión 3.3.


Este módulo contiene funciones para volcar los rastreos de Python explícitamente, en un fallo, después de un tiempo de espera o en una señal del usuario. Llame a faulthandler.enable() para instalar los gestores de fallos para las señales SIGSEGV, SIGFPE, SIGABRT, SIGBUS, y SIGILL. También puede activarlos al inicio estableciendo la variable de entorno PYTHONFAULTHANDLER o usando la opción de línea de comandos -X faulthandler.

El gestor de fallos es compatible con el gestor de fallos del sistema como Apport o el gestor de fallos de Windows. El módulo utiliza una pila alternativa para los gestores de señales si la función sigaltstack() está disponible. Esto le permite volcar el rastreo incluso en un desbordamiento de pila.

El gestor de fallos se llama en casos catastróficos y, por lo tanto, solo puede utilizar funciones seguras en señales (por ejemplo, no puede asignar memoria en el heap). Debido a esta limitación, el volcado del rastreo es mínimo comparado a los rastreos normales de Python:

  • Solo se soporta ASCII. El gestor de errores backslashreplace se utiliza en la codificación.

  • Cada cadena de caracteres está limitada a 500 caracteres.

  • Solo se muestran el nombre de archivo, el nombre de la función y el número de línea. (sin código fuente)

  • Está limitado a 100 frames y 100 hilos.

  • El orden se invierte: la llamada más reciente se muestra primero.

Por defecto, el rastreo de Python se escribe en sys.stderr. Para ver los rastreos, las aplicaciones deben ejecutarse en la terminal. Alternativamente se puede pasar un archivo de registro a faulthandler.enable().

El módulo está implementado en C, así los rastreos se pueden volcar en un fallo o cuando Python está en bloqueo mutuo.

El Modo de Desarrollo Python llama a failurehandler.enable() al inicio de Python.

Volcar el rastreo

faulthandler.dump_traceback(file=sys.stderr, all_threads=True)

Vuelca los rastreos de todos los hilos en el archivo file. Si all_threads es False, vuelca solo el hilo actual.

Distinto en la versión 3.5: Se añadió soporte para pasar el descriptor de archivo a esta función.

Estado del gestor de fallos

faulthandler.enable(file=sys.stderr, all_threads=True)

Activa el gestor de fallos: instala gestores para las señales SIGSEGV, SIGFPE, SIGABRT, SIGBUS y SIGILL para volcar el rastreo de Python. Si all_threads es True, produce rastreos por cada hilo activo. De lo contrario, vuelca solo el hilo actual.

El archivo file se debe mantener abierto hasta que se desactive el gestor de fallos: ver problema con descriptores de archivo.

Distinto en la versión 3.5: Se añadió soporte para pasar el descriptor de archivo a esta función.

Distinto en la versión 3.6: En Windows, también se instaló un gestor para la excepción de Windows.

faulthandler.disable()

Desactiva el gestor de fallos: desinstala los gestores de señales instalados por enable().

faulthandler.is_enabled()

Comprueba si el gestor de fallos está activado.

Volcar los rastreos después de un tiempo de espera

faulthandler.dump_traceback_later(timeout, repeat=False, file=sys.stderr, exit=False)

Vuelca los rastreos de todos los hilos, después de un tiempo de espera de timeout segundos, o cada timeout segundos si repeat es True. Si exit es True, llama a _exit() con status=1 después de volcar los rastreos. (Nota: _exit() termina el proceso inmediatamente, lo que significa que no hace ninguna limpieza como vaciar los buffers de archivos.) Si la función se llama dos veces, la nueva llamada reemplaza los parámetros previos y reinicia el tiempo de espera. El temporizador tiene una resolución de menos de un segundo.

El archivo file se debe mantener abierto hasta que se vuelque el rastreo o se llame a cancel_dump_traceback_later(): ver problema con descriptores de archivo.

Esta función está implementada utilizando un hilo vigilante.

Distinto en la versión 3.7: Ahora esta función está siempre disponible.

Distinto en la versión 3.5: Se añadió soporte para pasar el descriptor de archivo a esta función.

faulthandler.cancel_dump_traceback_later()

Cancela la última llamada a dump_traceback_later().

Volcar el rastreo en una señal del usuario

faulthandler.register(signum, file=sys.stderr, all_threads=True, chain=False)

Registra una señal del usuario: instala un gestor para la señal signum para volcar el rastreo de todos los hilos, o del hilo actual si all_threads es False, en el archivo file. Llama al gestor previo si chain es True.

El archivo file se debe mantener abierto hasta que la señal sea anulada por unregister(): ver problema con descriptores de archivo.

No está disponible en Windows.

Distinto en la versión 3.5: Se añadió soporte para pasar el descriptor de archivo a esta función.

faulthandler.unregister(signum)

Anula una señal del usuario: desinstala el gestor de la señal signum instalada por register(). Retorna True si la señal fue registrada, False en otro caso.

No está disponible en Windows.

Problema con descriptores de archivo

enable(), dump_traceback_later() y register() guardan el descriptor de archivo de su argumento file. Si se cierra el archivo y su descriptor de archivo es reutilizado por un nuevo archivo, o si se usa os.dup2() para reemplazar el descriptor de archivo, el rastreo se escribirá en un archivo diferente. Llame a estas funciones nuevamente cada vez que se reemplace el archivo.

Ejemplo

Ejemplo de un fallo de segmentación en Linux con y sin activar el gestor de fallos:

$ 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