• 线程 转储



    线程转储(Thread Dump)就是JVM中所有线程状态信息的一次快照。

    线程转储一般使用文本格式, 可以将其保存到文本文件中, 然后人工查看和分析, 或者使用工具/API自动分析。我们一般使用JDK自带的命令行工具来获取Java应用程序的线程转储。

    1. JSTACK

      jstack 是JDK内置的一款命令行工具, 专门用来查看线程状态, 也可以用来执行线程转储。

      一般先通过 jps 或者 ps 命令找到Java进程对应的pid, 然后在控制台中通过pid来输出线程转储。 当然, 我们也可以将输出内容重定向到某个文件中。

      使用jstack工具获取线程转储的基本参数格式为:

    jstack [-F] [-l] [-m] 

      对应的参数选项是可选的。 具体含义如下:

    1. -F 选项, 强制执行线程转储; 有时候 jstack pid 会假死, 则可以加上 -F 标志
    2. -l 选项, 会查找堆内存中拥有的同步器以及资源锁
    3. -m 选项, 额外打印 native栈帧(C和C++的)

    例如, 获取线程转储并将结果输出到文件:

    1. [root@cwy-hbcsh-zyl-1 HDTool]# jps
    2. 22387 jar
    3. 25524 Jps
    4. 17925 jar
    5. 13383 jar
    6. 21422 jar
    7. [root@cwy-hbcsh-zyl-1 HDTool]# jstack -F 17925 > /opt/HDTool/threaddump.txt
    8. [root@cwy-hbcsh-zyl-1 HDTool]#

    2. JCMD

      jcmd是非常强大的本地工具, 支持Java 8及更高版本。使用以下jcmd命令,可以生成线程转储。

    jcmd <pid> Thread.print > <file-path>

      例如, 获取线程转储并将结果输出到文件:

    [root@cwy-hbcsh-zyl-1 HDTool]# jcmd 17925 Thread.print > /opt/HDTool/dump.txt

  • 相关阅读:
    udp多点通信-广播-组播
    驱动开发:内核通过PEB得到进程参数
    单据分页的实现
    Linux-CPU之上下文切换
    AWS-Basic-S3
    【Microelectronic Systems】
    yolo改进替换VanillaNet backbone
    1-深度学习绪论讲解
    算法题笔记 6-10 (青蛙跳台阶)
    跟着Nature Plant学图形颜色搭配 | caecopal包
  • 原文地址:https://blog.csdn.net/silgen/article/details/133159823