java线程池与tomcat线程池策略算法上的区别

Posted Java开发者之路

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java线程池与tomcat线程池策略算法上的区别相关的知识,希望对你有一定的参考价值。


java线程池





如果当前运行的线程,少于corePoolSize,则创建一个新的线程来执行任务。

如果运行的线程等于或多于 corePoolSize,将任务加入 BlockingQueue。

如果 BlockingQueue 内的任务超过上限,则创建新的线程来处理任务。

如果创建的线程超出 maximumPoolSize,任务将被拒绝策略拒绝。




tomcat线程池





如果当前运行的线程,少于corePoolSize,则创建一个新的线程来执行任务。

如果线程数大于 corePoolSize了,Tomcat 的线程不会直接把线程加入到无界的阻塞队列中,而是去判断submittedCount(已经提交线程数)是否等于 maximumPoolSize。

如果等于,表示线程池已经满负荷运行,不能再创建线程了,直接把线程提交到队列,

如果不等于,则需要判断,是否有空闲线程可以消费。

如果有空闲线程则加入到阻塞队列中,等待空闲线程消费。

如果没有空闲线程,尝试创建新的线程。(这一步保证了使用无界队列,仍然可以利用线程的 maximumPoolSize)。

如果总线程数达到 maximumPoolSize,则继续尝试把线程加入 BlockingQueue 中。

如果 BlockingQueue 达到上限(假如设置了上限),被默认线程池启动拒绝策略,tomcat 线程池会 catch 住拒绝策略抛出的异常,再次把尝试任务加入中 BlockingQueue 中。

再次加入失败,启动拒绝策略。





以上是关于java线程池与tomcat线程池策略算法上的区别的主要内容,如果未能解决你的问题,请参考以下文章

Java线程池与java.util.concurrent

跟我学Java多线程——线程池与堵塞队列

Fork/Join 型线程池与 Work-Stealing 算法

高并发之——不得不说的线程池与ThreadPoolExecutor类浅析

Java多线程学习线程池与Executor 框架

java并发体系 -- 线程池与死锁