public void run() {
while (true)
;
}
}, “busyThreadName”);
t.start();
}
public static void createLockThread(final Object lock) {
Thread t = new Thread(new Runnable() {
@Override
public void run() {
synchronized(lock) {
try {
lock.wait();
}catch(InterruptedException e) {
e.printStackTrace();
}
}
}
},“lockThreadName”);
t.start();
}
public static void createDeadLock() {
Object a = new Object();
Object b = new Object();
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
synchronized (a) {
try {
Thread.sleep(3000);
synchronized (b) {
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
},“t1”);
Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
synchronized (b) {
try {
Thread.sleep(3000);
synchronized (a) {
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
},“t2”);
t1.start();
t2.start();
}
}
启动前
没有启动任何JAVA线程,CUP占用为0%
启动后
我们发现CPU被打满100%。进程为我们启动的程序。这个时候我们肯定想知道线程都在干什么。导致CUP消耗过高!那么具体怎么排查呢?
2、问题排查
获取进程ID
通过top命令可以看到,最消耗CUP的进程ID。如上图