加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

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会创建新的子进程,并跟踪它们).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读