线程转储

2023/5/25 1:22:24

本文主要是介绍线程转储,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

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

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

1. JSTACK

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

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

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

jstack [-F] [-l] [-m] <pid>

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

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

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

[root@cwy-hbcsh-zyl-1 HDTool]# jps
22387 jar
25524 Jps
17925 jar
13383 jar
21422 jar
[root@cwy-hbcsh-zyl-1 HDTool]# jstack -F 17925 > /opt/HDTool/threaddump.txt
[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 > dump.txt


这篇关于线程转储的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程