zoukankan      html  css  js  c++  java
  • Linux jstack命令详解

     jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息。  

    如果是在64位机器上,需要指定选项"-J-d64",Windows的jstack使用方式只支持以下的这种方式:jstack [-l] pid

    如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题。

    另外,jstack工具还可以附属到正在运行的java程序中,看到当时运行的java程序的java stack和native stack的信息, 如果现在运行的java程序呈现hung的状态,jstack是非常有用的。

    需要注意的问题:

    l 不同的 JAVA虚机的线程 DUMP的创建方法和文件格式是不一样的,不同的 JVM版本, dump信息也有差别。

    l 在实际运行中,往往一次 dump的信息,还不足以确认问题。建议产生三次 dump信息,如果每次 dump都指向同一个问题,我们才确定问题的典型性。 

    2、命令格式

    $jstack [ option ] pid

    $jstack [ option ] executable core

    $jstack [ option ] [server-id@]remote-hostname-or-IP

    参数说明:

    pid: java应用程序的进程号,一般可以通过jps来获得;

    executable:产生core dump的java可执行程序;

    core:打印出的core文件;

    remote-hostname-or-ip:远程debug服务器的名称或IP;

    server-id: 唯一id,假如一台主机上多个远程debug服务;

    示例:

    $jstack –l 23561

    线程分析:

    一般情况下,通过jstack输出的线程信息主要包括:jvm自身线程、用户线程等。其中jvm线程会在jvm启动时就会存在。对于用户线程则是在用户访问时才会生成。

    l jvm线程:

    在线程中,有一些 JVM内部的后台线程,来执行譬如垃圾回收,或者低内存的检测等等任务,这些线程往往在JVM初始化的时候就存在,如下所示:

     1 "Attach Listener" daemon prio=10 tid=0x0000000052fb8000 nid=0xb8f waiting on condition [0x0000000000000000]
     2 
     3    java.lang.Thread.State: RUNNABLE
     4 
     5  
     6 
     7    Locked ownable synchronizers:
     8 
     9         - None
    10 
    11 destroyJavaVM" prio=10 tid=0x00002aaac1225800 nid=0x7208 waiting on condition [0x0000000000000000]
    12 
    13    java.lang.Thread.State: RUNNABLE
    14 
    15  
    16 
    17    Locked ownable synchronizers:
    18 
    19         - None

    l 用户级别的线程

    还有一类线程是用户级别的,它会根据用户请求的不同而发生变化。该类线程的运行情况往往是我们所关注的重点。而且这一部分也是最容易产生死锁的地方。

     1 "qtp496432309-42" prio=10 tid=0x00002aaaba2a1800 nid=0x7580 waiting on condition [0x00000000425e9000]
     2 
     3    java.lang.Thread.State: TIMED_WAITING (parking)
     4 
     5         at sun.misc.Unsafe.park(Native Method)
     6 
     7         - parking to wait for  <0x0000000788cfb020> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)
     8 
     9         at java.util.concurrent.locks.LockSupport.parkNanos(LockSupport.java:198)
    10 
    11         at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.awaitNanos(AbstractQueuedSynchronizer.java:2025)
    12 
    13         at org.eclipse.jetty.util.BlockingArrayQueue.poll(BlockingArrayQueue.java:320)
    14 
    15         at org.eclipse.jetty.util.thread.QueuedThreadPool$2.run(QueuedThreadPool.java:479)
    16 
    17         at java.lang.Thread.run(Thread.java:662)
    18 
    19  
    20 
    21    Locked ownable synchronizers:
    22 
    23         - None

    从上述的代码示例中我们可以看到该用户线程的以下几类信息:

    Ø 线程的状态:waiting on condition(等待条件发生)

    Ø 线程的调用情况;

    Ø 线程对资源的锁定情况;

  • 相关阅读:
    03Qt信号与槽(2)
    01Qt中的隐式共享
    10GNU C语言函数调用
    09GNU C语言程序编译
    第一本C语言笔记(下)
    07控制器和控制卡(3)
    06控制器和控制卡(2)
    集合
    linux指令(目录类操作指令)
    面向对象三大特征
  • 原文地址:https://www.cnblogs.com/wspblog/p/4651971.html
Copyright © 2011-2022 走看看