java如何查看线程死锁?
jstack
jstack是Java虚拟机自带的一种堆栈跟踪工具,可以用来打印出给定Java进程ID(PID)的Java线程的堆栈跟踪信息。通过多次执行jstack命令并观察输出结果,可以判断是否存在线程死锁。步骤:1. 首先,找到Java进程的PID。可以使用jps命令列出所有Java进程及其PID。2. 然后,使用jstack 命令查看该进程的线程堆栈信息。3. 多次执行jstack命令,观察输出结果中是否有线程状态长时间保持不变,且处于等待对方释放锁的状态,这通常表明存在死锁。
使用jconsole和jvisualvm
这两个工具都是Java监控和管理控制台(JMX)的一部分,提供了图形界面来查看和管理Java应用程序。步骤:• 启动jconsole或jvisualvm,连接到正在运行的Java应用程序。• 在工具中查看线程状态,特别是寻找处于BLOCKED状态的线程,这些线程可能正在等待获取锁。• jvisualvm还提供了线程转储(Thread Dump)功能,可以直接查看线程的堆栈信息,便于分析死锁
以下是一个简单的Java线程死锁示例:
public class DeadlockExample {
private static final Object resource1 = new Object();
private static final Object resource2 = new Object();
public static void main(String[] args) {
Thread thread1 = new Thread(() -> {
synchronized (resource1) {
System.out.println("Thread 1: Locked resource 1");
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (resource2) {
System.out.println("Thread 1: Locked resource 2");
}
}
});
Thread thread2 = new Thread(() -> {
synchronized (resource2) {
System.out.println("Thread 2: Locked resource 2");
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (resource1) {
System.out.println("Thread 2: Locked resource 1");
}
}
});
thread1.start();
thread2.start();
}
}
线程1首先锁定resource1,然后尝试锁定resource2;线程2首先锁定resource2,然后尝试锁定resource1。由于两个线程都持有一个资源并等待另一个资源,从而形成了死锁。
jstack打印Java线程的堆栈跟踪信息手动分析线程死锁
jconsole图形界面查看和管理Java应用程序动态监控线程状态
jvisualvm图形界面监控和管理Java应用程序,提供线程转储功能动态监控和详细分析线程死锁
参考 https://mp.weixin.qq.com/s/9lVfXpvKpuUCmAlKtpEiHw