linux – 在运行的JBoss进程上无法“strace -p”
发布时间:2020-12-13 19:34:41 所属栏目:Linux 来源:网络整理
导读:我试图使用“strace -p”附加到已经运行的JBoss进程. JBoss正在使用1.5.0_15 Java JDK.不幸的是,这不行 – 我只得到一个单独的futex()结果: # strace -p 3388Process 3388 attached - interrupt to quit[ Process PID=3388 runs in 32 bit mode. ]futex(0x8
我试图使用“strace -p”附加到已经运行的JBoss进程. JBoss正在使用1.5.0_15
Java JDK.不幸的是,这不行 – 我只得到一个单独的futex()结果:
# strace -p 3388 Process 3388 attached - interrupt to quit [ Process PID=3388 runs in 32 bit mode. ] futex(0x8f18f7c,FUTEX_WAIT_PRIVATE,1,NULL <unfinished ...> Strace适用于所有其他程序,但不适用于JBoss.当我通过strace启动进程时,它似乎工作正常.当我尝试附加到已经运行的进程时它不起作用. 我使用64位Linux 2.6.18与32位Java JDK(如果重要的话,RedHat Enterprise Linux 5.3). 更新#1: 我尝试使用“-d”运行它,但输出似乎没有更多的见解,至少对我来说: [root@]# strace -d -e verbose=all -p 3388 Process 3388 attached - interrupt to quit [wait(0x137f) = 3388] pid 3388 stopped,[SIGSTOP] [wait(0x57f) = 3388] pid 3388 stopped,[SIGTRAP] [ Process PID=3388 runs in 32 bit mode. ] futex(0x8f18f7c,NULL 解决方法
如果该进程中有多个线程,则需要给出strace多个-p选项,指定每个线程的ID.看起来你是成功跟踪原来的父线程,它什么都不做,只是等待其他一些线程完成.
(当您从strace启动命令时,它起作用的原因是,默认情况下,strace会创建新的子进程,并跟踪它们). (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |