监控Java线程池里的状态

本文转自:干货:教你如何监控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():总线程数复制代码


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值