我正在运行pstack来查找在两台机器上运行的应用程序的函数堆栈(两台RHEL)
在我的一台机器中,它按预期工作
[root@civ4cez191 bin]# pstack 22947
Thread 2 (Thread 0x7f63cbe7d700 (LWP 22949)):
#0 0x0000003c3640f0cd in pause () from /lib64/libpthread.so.0
#1 0x0000000000485a78 in _signalWaitThread(void*) ()
#2 0x0000003c36407aa1 in start_thread () from /lib64/libpthread.so.0
#3 0x0000003c360e8aad in clone () from /lib64/libc.so.6
Thread 1 (Thread 0x7f63d2d07700 (LWP 22947)):
#0 0x0000003c360e1523 in select () from /lib64/libc.so.6
#1 0x00000000004ccc36 in TFDSETSelect(void*, void*, int) ()
#2 0x00000000004cb50f in SvrInit1(unsigned int (*)(void*, void**), unsigned int (*)(void*, void*, void**, unsigned int*), void (*)(void*), unsigned int (*)(unsigned short, unsigned short), void (*)(unsigned short, unsigned short), void (*)(unsigned short, unsigned short), unsigned short, unsigned char, unsigned short, unsigned char) ()
#3 0x00000000004259f0 in main ()
但是在其他机器中它只是打印线程的名称
[root@civ4cez194 bin]# pstack 12672
Thread 7 (Thread 0x7f01892e2700 (LWP 12674)):
Thread 6 (Thread 0x7f0188aa0700 (LWP 12743)):
Thread 5 (Thread 0x7f0188a1e700 (LWP 7090)):
Thread 4 (Thread 0x7f0188a5f700 (LWP 7127)):
Thread 3 (Thread 0x7f01889dd700 (LWP 7178)):
Thread 2 (Thread 0x7f0188ae1700 (LWP 7235)):
Thread 1 (Thread 0x7f0193ca0740 (LWP 12672)):
我已经找到了解决这个问题的方法但是没有取得多大成功。 我发现的重要信息只有here
对于要转储的线程信息,您必须使用 LinuxThreads libpthread.so库的调试感知版本。
(要检查,请在pthreads库上运行nm(1),然后执行 确保符号" __ pthread_threads_debug"是 新的NPTL libpthread.so不支持线程 库。
在两台机器上对/lib64/libpthread.so.0执行nm时,我发现" __ pthread_debug"对于两者。
非常感谢帮助。
答案 0 :(得分:0)
所以事实证明在设置上有python安装问题,因为回溯无法正常工作,修复python安装修复了问题。