Maison >développement back-end >Tutoriel Python >Comment obtenir une trace de pile d'une application Python en cours d'exécution ?
Inspection de la trace de pile d'une application Python en cours d'exécution
Lorsqu'une application Python se bloque de manière inattendue, il peut être difficile de déterminer la source du problème . Heureusement, il existe des techniques pour obtenir une trace de pile de l'application en cours d'exécution, vous permettant d'identifier le code spécifique en cours d'exécution lorsque l'application s'arrête.
Utilisation d'un gestionnaire de signaux personnalisé
Une méthode pour afficher une trace de pile consiste à utiliser un gestionnaire de signal personnalisé. Cette technique consiste à envoyer un signal à l'application en cours d'exécution, déclenchant le gestionnaire pour capturer la trace de la pile et l'afficher de manière interactive. Vous trouverez ci-dessous un exemple utilisant la fonction debug :
<code class="python">import code, traceback, signal def debug(sig, frame): d={'_frame':frame} d.update(frame.f_globals) d.update(frame.f_locals) i = code.InteractiveConsole(d) message = "Signal received : entering python shell.\nTraceback:\n" message += ''.join(traceback.format_stack(frame)) i.interact(message) def listen(): signal.signal(signal.SIGUSR1, debug) </code>
Une fois la fonction Listen() invoquée, l'envoi d'un signal SIGUSR1 au processus à l'aide de os.kill ou kill interrompra l'application en cours d'exécution, fournissant ainsi une console Python. avec la trace de la pile.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!