jstack命令可以查看JVM内所有的线程运行情况。
语法
jstack [-l] -[e] pid
参数说明:
l
: 打印关于锁的附加信息
e
: 打印关于线程的附加信息,这个参数用的较少
常用的命令
查看JVM中所有的线程运行情况
jstack -l JVM进程ID | more
当JVM中存在死锁时,在jstack输出信息的最后会有提示:
统计线程数量
搜索关键字java.lang.Thread.State
,可以统计出线程总数
jstack -l JVM进程ID | grep 'java.lang.Thread.State' | wc -l
导出JVM中的线程信息到dump文件
jstack -l JVM进程ID > jvm_thread.dump
该文件可以使用Notepad++等文本工具直接打开。
dump文件分析工具
个人常用的线程dump文件分析工具是FastThread
下面是通过FastThread工具分析一个有死锁dump文件的部分截图: