在jdk所在目录bin目录下,双击“jconsole”,即可打开。
启动jconsole之后,将自动搜索出本机所有虚拟机进程;双击其中一个即可监控。
选择一条,进入
用于监视收集器管理的虚拟机内存(Java堆和永久代)的变化趋势。
static class oom{
public byte[] placeholder = new byte[64*1024];
}
public static void fillhead(int num) throws InterruptedException{
ArrayList
System.out.println("start");
for(int i=0;i
Thread.sleep(50);
l.add(new oom());
}
System.out.println("its over");
System.gc();
}
public static void main(String[] args) throws InterruptedException {
fillhead(1000);
}
3.线程监控
可以对线程进行监控分析。
线程长时间停顿的主要原因有:a)请求外部资源(数据库、网络资源、设备资源等);b)线程锁(死锁、活锁);c)死循环。
/**
* 线程死循环演示
*/
static void createBusyThread(){
Thread t = new Thread(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
while(true);
}
},"TestBusyThread");
t.start();
}
static void createLockedThread(final Object lock){
Thread t = new Thread(new Runnable() {
@Override
public void run() {
synchronized (lock) {
try {
lock.wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
},"TestLockedThread");
t.start();
}
public static void main(String[] args) throws IOException {
/*BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
br.readLine();*/
createBusyThread();
createLockedThread(new Object());
//System.gc();
}
二、VisualVM:多合一故障处理工具
参考这位大神的总结:http://www.cnblogs.com/wade-xu/p/4369094.html