监控Java线程池里的状态

3,339 阅读5分钟

本文转自:干货:教你如何监控Java线程池运行状态

线程池执行类ThreadPoolExecutor给了相关的API来监控某一个线程池的执行状态,能实时获取线程池当前活动线程数、正在排队线程数、已执行线程数、总线程数等。

总线程数 = 排队线程数 + 活动线程数 + 执行完成的线程数

首先我们来创建1000个线程的线程池:

private static ExecutorService es = new ThreadPoolExecutor(50, 100, 0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>(1000));

然后再来写一个监控方法:

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);
}

执行结果如下:

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

可以看出:

活动的线程数和总线程数是不变的,排队中的和完成的是每次都在变化。

其中ThreadPoolExecutor提供的API方法如下:

getQueue().size():获取当前排队线程
getActiveCount(): 获取当前活动的线程
getCompletedTaskCount:已完成的线程
getTaskCount():总线程数