`
spring5365
  • 浏览: 72044 次
  • 性别: Icon_minigender_1
  • 来自: 钓鱼岛
社区版块
存档分类
最新评论

jstack命令

 
阅读更多

jstack(Stack Trace for Java)
用于查看java程序的java stack和native stack的信息。

 

命令格式
jstack [ options ]  vmid

jstack [ options ] [server-id@]remote-hostname-or-IP

 

常用参数说明
-m 如果调用的是本地方可以显示C or C++的堆栈。

-l   显示堆栈和锁的附加信息,如ownable synchronizers列表

 

示例:1

"Thread-2" prio=6 tid=0x19ea1000 nid=0x4810 at breakpoint[0x1a25f000]

   java.lang.Thread.State: RUNNABLE

        at com.shunwang.meteor.example.ConditionExample$ProductQueue.put(ConditionExample.java:65)

        at com.shunwang.meteor.example.ConditionExample$1.run(ConditionExample.java:19)

        at java.lang.Thread.run(Thread.java:619)

 

   Locked ownable synchronizers:

        - None

 

"Thread-1" prio=6 tid=0x025ef800 nid=0x3ec0 at breakpoint[0x1a1cf000]

   java.lang.Thread.State: RUNNABLE

        at com.shunwang.meteor.example.ConditionExample$ProductQueue.put(ConditionExample.java:65)

        at com.shunwang.meteor.example.ConditionExample$1.run(ConditionExample.java:19)

        at java.lang.Thread.run(Thread.java:619)

 

   Locked ownable synchronizers:

        - None

 

"Thread-0" prio=6 tid=0x025ef000 nid=0x671c runnable [0x1a13f000]

   java.lang.Thread.State: RUNNABLE

        at java.io.FileOutputStream.writeBytes(Native Method)

        at java.io.FileOutputStream.write(FileOutputStream.java:260)

        at java.io.BufferedOutputStream.flushBuffer(BufferedOutputStream.java:65)

        at java.io.BufferedOutputStream.flush(BufferedOutputStream.java:123)

        - locked <0x09b43270> (a java.io.BufferedOutputStream)

        at java.io.PrintStream.write(PrintStream.java:432)

        - locked <0x09b40898> (a java.io.PrintStream)

        at sun.nio.cs.StreamEncoder.writeBytes(StreamEncoder.java:202)

        at sun.nio.cs.StreamEncoder.implFlushBuffer(StreamEncoder.java:272)

        at sun.nio.cs.StreamEncoder.flushBuffer(StreamEncoder.java:85)

        - locked <0x09b432b0> (a java.io.OutputStreamWriter)

        at java.io.OutputStreamWriter.flushBuffer(OutputStreamWriter.java:168)

        at java.io.PrintStream.newLine(PrintStream.java:496)

        - locked <0x09b40898> (a java.io.PrintStream)

        at java.io.PrintStream.println(PrintStream.java:687)

        - locked <0x09b40898> (a java.io.PrintStream)

        at com.shunwang.meteor.example.ConditionExample$ProductQueue.put(ConditionExample.java:82)

        at com.shunwang.meteor.example.ConditionExample$1.run(ConditionExample.java:19)

        at java.lang.Thread.run(Thread.java:619)

 

   Locked ownable synchronizers:

        - <0x09b43328> (a java.util.concurrent.locks.ReentrantLock$NonfairSync)

 

"Low Memory Detector" daemon prio=6 tid=0x025e6c00 nid=0xafa8 runnable [0x00000000]

   java.lang.Thread.State: RUNNABLE

 

   Locked ownable synchronizers:

 

        - None

分享到:
评论

相关推荐

    抓取jstack方法及解决system用户执行jstack命令权限问题

    抓取jstack方法及解决system用户执行jstack命令权限问题, 打开cmd窗口,输入命令 jstack -l 49824&gt;&gt;C:/error01.txt 其中49824为tomcat8.0 的pid ; error01.txt 这个可以自己取名字 多输出几份jstack 文件,做比对...

    如何通过jstack命令dump线程信息

    `jstack`命令是Java开发中用于诊断线程堆栈信息的重要工具,它可以帮助开发者了解Java应用程序的线程状态,包括运行、等待、阻塞等,以及是否存在死锁等问题。当遇到性能问题或者线程卡住不前时,`jstack`能提供关键...

    输出java进程的jstack信息示例分享 通过线程堆栈信息分析java线程

    jstack命令通常可以输出以下类型的信息: 1. 线程的完整堆栈跟踪,包括本地方法。 2. 显示每个Java线程的状态,例如等待、运行、阻塞等。 3. 显示守护线程和非守护线程。 4. 显示Java和本机锁的锁定情况。 使用...

    Kubernetes应用java程序无法使用jmap,jstack的解决方案.docx

    在 Kubernetes 环境中,运行 Java 程序时,无法使用 jmap 和 jstack 命令进行性能分析和诊断。这种情况下,无法获取 Java 进程的 pid,导致无法使用 jmap 和 jstack 命令。 解决方案: 1. 了解 Linux 特殊进程 在 ...

    Java线程Dump分析工具jstack解析及使用场景

    jstack命令的基本格式如下: ``` jstack [-l] [-F] pid ``` 其中,`pid` 是Java进程的ID,`-l` 选项会提供更详细的线程和锁信息,而 `-F` 选项则用于在进程无响应时强制打印堆栈信息。 当Java程序出现挂起(hung)...

    MPP的jstack分析结果

    通过执行jstack命令,我们可以获取到以下关键信息: 1. **线程状态**:jstack会列出所有活动线程及其当前的状态,包括运行(RUNNABLE)、等待(WAITING)、阻塞(BLOCKED)等。这有助于我们识别哪些线程可能在消耗...

    使用jstack定位分析CPU消耗问题.docx

    4. 使用 jstack 命令保存 JVM 进程对应的栈信息,具体命令为:jstack &lt;PID&gt; &gt; 1-stack。 5. 多次记录线程堆栈的快照,方面后续在快照中找对应的线程调用内容。 6. 使用 top 命令找到占用 CPU 较多时间的线程,具体...

    jstack生成的Thread Dump日志1

    【描述】:jstack命令用于生成Java应用程序的线程堆栈跟踪,它可以帮助开发者诊断Java应用中的线程问题。线程Dump日志提供了详细的线程状态和调用栈信息,这对于理解和解决线程阻塞、死锁等问题至关重要。如果堆栈...

    java虚拟机常用命令

    jstack命令用于生成Java虚拟机当前的线程快照信息,包含每一条线程的堆栈信息。它通常用于定位线程停顿的原因,比如死锁、死循环等。jstack命令的基本格式为: ``` jstack [option] jstack [option] &lt;executable&gt; ...

    05-VIP-JVM调优工具详解(预习资料)1

    在实际应用中,可以使用Jmap命令查看内存信息,使用Jvisualvm可视化性能数据,使用Jstack命令找到死锁和高CPU使用率的线程,使用JMX远程监控和管理Java应用程序。这些工具可以帮助开发者和运维人员更好地了解JVM的...

    10.JVM常见命令1

    在本文中,我们将介绍 10 个常见的 JVM 命令,包括 jps、jstat、jinfo、jmap 和 jstack 等。 jps 命令 jps 命令是 JVM 进程状态工具,用于显示指定系统内所有的 HotSpot 虚拟机的进程状态。它可以列出当前运行在...

    Linux性能检查命令总结

    * jstack 命令:查看线程是否存在死锁。 * grep 命令:查看日志文件中包含特定异常数量。 Linux 性能检查命令总结是指在 Linux 服务器出现性能问题时,使用的一些命令来快速定位和解决问题。这可以帮助管理员快速...

    58速运:线上服务CPU100%问题快速定位实战1

    pstack和jstack命令都是用来查看进程堆栈的工具。通过使用这两个命令,我们可以查看进程堆栈,找到线程在干嘛。使用grep命令可以过滤得到线程堆栈,快速地找到问题所在。 知识点6:快速定位问题代码 通过使用top、...

    JVM优化|java虚拟机优化

    - 掌握jstack命令的使用 - 掌握VisualJVM工具的使用 - 了解什么是垃圾回收 - 掌握垃圾会回收的常见算法 - 学习串行、并行、并发、G1垃圾收集器 - 学习GC日志的可视化查看 - Tomcat8的优化 - 看懂Java底层字节码 - ...

    Java内存泄露_JVM监控工具介绍

    jstack命令是一个强大的工具,用于分析Java程序的崩溃原因和堆栈信息。它可以将core文件转换为人类可读的格式,方便开发者快速定位问题所在。如果Java程序崩溃生成core文件,jstack工具可以用来获得core文件的Java栈...

    解决java程序运行慢问题.doc

    jstack 命令可以统计 stack 中总是在等待哪些锁,可以对锁 id 进行排序统计。例如,可以使用 jstack -l pid 命令来统计 stack 中总是在等待哪些锁,然后对锁 id 进行排序统计。 五、 其他解决方案 除了上述方法外...

    JVM调优工具命令详解.pdf

    文档中提供了jstack命令的用法,该命令通过进程ID来帮助开发者查找Java程序中的死锁情况。例如: 1. jstack &lt;pid&gt;:通过指定的进程ID,jstack能够分析Java堆栈跟踪信息,并且能检测到被阻塞的线程以及它们所持有的...

    Java性能调优命令

    3. jstack命令用于产生运行中的Java线程的dump信息。它能打印出Java线程的堆栈跟踪,帮助开发者发现哪些线程被阻塞、等待或者处于运行状态。例如,`jstack pid`命令用于查看进程id为pid的Java线程的堆栈信息。 4. ...

    java问题快速定位

    - `jrcmd [pid] -cmd jstack`:远程执行jstack命令。 - `jrcmd [pid] -cmd jstat -gc`:远程执行jstat命令查看GC信息。 通过`jrcmd`可以在不直接登录服务器的情况下获取到Java进程的状态信息,这对于远程诊断问题...

    java进程高CPU占用故障排查.txt

    4. **使用jstack命令获取线程堆栈信息**: ```shell [root@localhost logs]# jstack 2633 | grep e18 -A 30 ``` `jstack`命令能够打印出Java进程中各个线程的堆栈信息。通过结合`grep`命令,可以筛选出特定线程...

Global site tag (gtag.js) - Google Analytics