查看运行中的python脚本的堆栈

转载自:http://www.708luo.com/?p=32

对于c/c++程序,我们可以在运行过程中通过pstack来查看程序当前的执行堆栈。

那么对于python脚本呢?

 

方法一:

如果脚本是前台运行,可以直接Ctrl+c中止该脚本,即可查看当前的执行堆栈。

如果脚本是后台运行的,可以先fg jobid,然后直接Ctrl+c中止脚本。当前的执行堆栈会被打印到脚本后台运行时的输出中(如果是./test.py &运行则是输出到前台;如果是nohup ./test.py &运行则是输出到nohup.out;如果加了输出重定向,则是打印到重定向的输出文件中)

 

方法二:

通过pdb完成,主要是为python脚本设置一个signal_handler,在其hang住的时候发送信号给它,然后进入debug模式。这时可以用w命令打印出当前执行堆栈。

参考这里http://blog.csdn.net/toymaker/article/details/6982131

不过这个方式,对后台运行的程序无效(不管是否先将程序转到前台)。而且需要提前加部分代码,对于已经在运行中的脚本无效。

好处是,如果程序是前台运行的,进入debug模式之后还可以继续运行,而不像方法一直接就终止脚本了。(有一点要注意的是:如果脚本处于sleep状态,经过信号处理之后sleep就被唤醒了)

 

方法三:

使用gdb打印python脚本当前执行堆栈。(不依赖gdb版本)

具体使用方式:

1. 编译带调试符号的python解析器:编译python时使用make "CFLAGS=-g -fno-inline -fno-strict-aliasing"

2. 添加gdb中可以使用的函数:从这里下载文件,将其内容写入到~/.gdbinit中(gdb 7.*版本无需此操作)

3. 运行gdb python <pid> 来attach到python进程

4. 运行pystack即可打印出堆栈

该方式不会终止脚本,所以如果可以的话,推荐使用这种方式。

该方法官方文档在这里

 

方法四:

使用gdb打印python脚本当前执行堆栈。(需要gdb 7.*版本,未成功尝试)

该方法在这里有说明。

尝试时遇到" RuntimeError: No type named size_t."错误,关于该错误的说明,可以查看这里

原文链接: https://www.cnblogs.com/wujianlundao/archive/2012/11/06/2757215.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍

    查看运行中的python脚本的堆栈

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/68391

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年2月9日 下午1:18
下一篇 2023年2月9日 下午1:19

相关推荐