死锁排查
什么是死锁
死锁代码编写
package com.coding.lock;
import java.util.concurrent.TimeUnit;
public class DeadLockDemo {
public static void main(String[] args) {
String lockA = "lockA";
String lockB = "lockB";
new Thread(new MyLockThread(lockA,lockB),"T1").start();
new Thread(new MyLockThread(lockB,lockA),"T2").start();
}
}
class MyLockThread implements Runnable{
private String lockA;
private String lockB;
public MyLockThread(String lockA, String lockB) {
this.lockA = lockA;
this.lockB = lockB;
}
@Override
public void run() {
synchronized (lockA){
System.out.println(Thread.currentThread().getName()+"lock:"+lockA+"=>get:"+lockB);
try {
TimeUnit.SECONDS.sleep(2);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lockB){
System.out.println(Thread.currentThread().getName()+"lock:"+lockB+"=>get:"+lockA);
}
}
}
}
排查
1.jps命令
获取当前运行的java进程号: jps -l
查看信息: jstack 进程号
2.jconsole 查看对应的信息!(可视化工具!)