jstack命令可以查看JVM内所有的线程运行情况。
语法jstack [-l] -[e] pid
常用的命令 查看JVM中所有的线程运行情况参数说明:
l : 打印关于锁的附加信息
e : 打印关于线程的附加信息,这个参数用的较少
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文件的部分截图:



