本文转自:干货:教你如何监控Java线程池运行状态bash
线程池执行类ThreadPoolExecutor给了相关的API来监控某一个线程池的执行状态,能实时获取线程池当前活动线程数、正在排队线程数、已执行线程数、总线程数等。spa
总线程数 = 排队线程数 + 活动线程数 + 执行完成的线程数
首先咱们来建立1000个线程的线程池:线程
private static ExecutorService es = new ThreadPoolExecutor(50, 100, 0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>(1000));复制代码
而后再来写一个监控方法:code
for (int i = 0; i < 1000; i++) {
es.execute(() -> {
System.out.print(1);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
});
}
ThreadPoolExecutor tpe = ((ThreadPoolExecutor) es);
while (true) {
System.out.println();
int queueSize = tpe.getQueue().size();
System.out.println("当前排队线程数:" + queueSize);
int activeCount = tpe.getActiveCount();
System.out.println("当前活动线程数:" + activeCount);
long completedTaskCount = tpe.getCompletedTaskCount();
System.out.println("执行完成线程数:" + completedTaskCount);
long taskCount = tpe.getTaskCount();
System.out.println("总线程数:" + taskCount);
Thread.sleep(3000);
}复制代码
执行结果以下:get
11111111111111111111111111111111111111111111111111
当前排队线程数:950
当前活动线程数:50
执行完成线程数:0
总线程数:1000
11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
当前排队线程数:840
当前活动线程数:50
执行完成线程数:110
总线程数:1000
111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
当前排队线程数:699
当前活动线程数:50
执行完成线程数:251
1总线程数:1000
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
1当前排队线程数:549
当前活动线程数:50
执行完成线程数:401
总线程数:1000
11111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
当前排队线程数:400
当前活动线程数:50
执行完成线程数:550
总线程数:1000
111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
当前排队线程数:250
当前活动线程数:50
执行完成线程数:700
总线程数:1000
111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
当前排队线程数:100
当前活动线程数:50
执行完成线程数:850
总线程数:1000
1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111
当前排队线程数:0
当前活动线程数:0
执行完成线程数:1000
总线程数:1000
复制代码
能够看出:string
活动的线程数和总线程数是不变的,排队中的和完成的是每次都在变化。it
其中ThreadPoolExecutor提供的API方法以下:io
getQueue().size():获取当前排队线程
getActiveCount(): 获取当前活动的线程
getCompletedTaskCount:已完成的线程
getTaskCount():总线程数复制代码