nid java_java – jstack输出缺少tid和nid信息

在Linux环境中,CPU利用率高的Java进程导致问题。尝试使用jstack获取线程详细信息,但遇到了无法打开socket文件的错误。使用-F选项后,虽然成功强制输出,但结果中未包含tid和nid。同时,-F -l和-F -m组合使用时,命令似乎被锁定,且-m选项提供的Java堆栈信息不足。如何正确获取包含tid和nid的完整Java堆栈信息成为当前挑战。
摘要由CSDN通过智能技术生成

我有一个

Linux盒子,CPU利用率几乎达到最大化.我使用top来追踪有问题的Java进程(12462)和底层线程(12465和12466).我希望运行jstack并在输出中搜索30b1和30b2(前面提到的线程转换为十六进制),这样我就可以弄清楚Java正在做什么.

当我运行没有任何标志的jstack时,它返回以下错误:

12462: Unable to open socket file: target process not responding or HotSpot VM not loaded

The -F option can be used when the target process is not responding

但是,当我运行jstack -F时,输出不包含tid或nid信息.这是输出的摘录:

Thread 31374: (state = IN_NATIVE)

- java.net.SocketInputStream.socketRead0(java.io.FileDescriptor, byte[], int, int, int) @bci=0 (Compiled frame; information may be imprecise)

- java.net.SocketInputStream.read(byte[], int, int, int) @bci=79, line=150 (Compiled frame)

- java.net.SocketInputStream.read(byte[], int, int) @bci=11, line=121 (Compiled frame)

- org.apache.coyote.http11.InternalInputBuffer.fill(boolean) @bci=59, line=516 (Compiled frame

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值