zoukankan      html  css  js  c++  java
  • java线程池与tomcat线程池策略算法上的异同

    java线程池
    如果当前运行的线程,少于corePoolSize,则创建一个新的线程来执行任务。
    如果运行的线程等于或多于 corePoolSize,将任务加入 BlockingQueue。
    如果 BlockingQueue 内的任务超过上限,则创建新的线程来处理任务。
    如果创建的线程超出 maximumPoolSize,任务将被拒绝策略拒绝。

    tomcat线程池
    如果当前运行的线程,少于corePoolSize,则创建一个新的线程来执行任务。
    如果线程数大于 corePoolSize了,Tomcat 的线程不会直接把线程加入到无界的阻塞队列中,而是去判断submittedCount(已经提交线程数)是否等于 maximumPoolSize。
    如果等于,表示线程池已经满负荷运行,不能再创建线程了,直接把线程提交到队列,
    如果不等于,则需要判断,是否有空闲线程可以消费。
    如果有空闲线程则加入到阻塞队列中,等待空闲线程消费。
    如果没有空闲线程,尝试创建新的线程。(这一步保证了使用无界队列,仍然可以利用线程的 maximumPoolSize)。
    如果总线程数达到 maximumPoolSize,则继续尝试把线程加入 BlockingQueue 中。
    如果 BlockingQueue 达到上限(假如设置了上限),被默认线程池启动拒绝策略,tomcat 线程池会 catch 住拒绝策略抛出的异常,再次把尝试任务加入中 BlockingQueue 中。
    再次加入失败,启动拒绝策略。

    一款用来看源码的工具: https://github.com/CoatiSoftware/Sourcetrail/releases

  • 相关阅读:
    scrapy.FormRequest与FormRequest.from_response 的区别
    可迭代对象和生成器
    css选择器
    xlwt写入excel时候的合并单元格
    html form提交的几种方式
    Python decorator 拦截器
    python manage.py makemigrations & migrate
    asianux4.5 环境, 本地yum源,局域网yum源的配置
    mysql基本操作
    sqlite-mysql migrate
  • 原文地址:https://www.cnblogs.com/lyhero11/p/12222376.html
Copyright © 2011-2022 走看看