是否可以使用线程转储找到线程的创建时间?

时间:2017-06-02 05:48:19

标签: multithreading jvm thread-dump jmap eclipse-memory-analyzer

我使用jmap -dump:format=b,file=<file.dump> <PID>命令生成JVM实例的线程转储。我只是想知道是否可以使用生成的线程转储找到在JVM实例中运行的线程的创建时间。

1 个答案:

答案 0 :(得分:2)

这是堆转储,而不是线程转储。没有关于堆转储中的线程创建时间的信息。但是,您可以从线程转储中找到它,如下所述。

  1. 使用jstack <PID>

  2. 转储线程
  3. 找到您感兴趣的主题的nid

    "Thread-7" #30 daemon prio=5 os_prio=0 tid=0x00002aaac9688800 nid=0x6945 runnable [0x00000000429c5000]
                                                                      ^^^^^^
       java.lang.Thread.State: RUNNABLE
            at sun.nio.ch.EPoll.epollWait(Native Method)
            at sun.nio.ch.EPollPort$EventHandlerTask.poll(EPollPort.java:194)
            at sun.nio.ch.EPollPort$EventHandlerTask.run(EPollPort.java:268)
            at java.lang.Thread.run(Thread.java:745)
    
  4. 将其转换为十进制:TID = 0x6945 = 26949

  5. 使用ps -Lo tid,lstart <PID> | grep <TID>

    获取开始时间
    26949 Tue May 30 19:16:29 2017