论tomcat线程池和spring封装的线程池

Tomcat 中的线程池是什么?

内部线程池:Tomcat 确实有一个内部的线程池,用于处理 HTTP 请求,通常是org.apache.tomcat.util.threads.ThreadPoolExecutor 类的实例。这个线程池专门用于处理进入的 HTTP 请求和发送响应。可以通过 Tomcat 的配置文件(如 server.xml)来调整这个线程池的参数,比如最大线程数、最小线程数等。这些配置影响的是 Tomcat 服务器的性能,而不是应用层面的线程处理。

Spring 中的线程池是什么?

应用层面的线程池:Spring 提供的线程池,是用于处理应用程序中的异步任务、定时任务等。这些线程池由开发人员配置和管理,与处理 HTTP 请求无关。可以通过 Spring 的配置文件或注解来灵活配置。

Tomcat 中的线程池和spring线程池区别

使用场景不同:Tomcat 线程池主要是内部自带的连接池为了处理 HTTP 请求,而不是在代码应用层面的处理我们的任务,而spring线程池就是我们平常在代码中使用的处理应用层面任务的

非核心线程创建时机不同:Tomcat的执行流程是当核心线程满了就直接创建非核心线程处理,而spring核心线程满了直接丢队列,如果队列满了在创建非核心线程处理

既然他们非核心线程创建时机不同,在某些业务场景下可以使用tomcat线程池执行任务吗?

答案肯定是不推荐,因为Tomcat 线程池主要为了处理 HTTP 请求,如果非要使用tomcat的线程池处理任务,可能会导致资源争抢影响性能,并且它的线程池配置在配置文件中固定的不够灵活,也不能随时调整线程数和拒绝策略,使用他处理代码任务只会变得更复杂,

你可能感兴趣的:(Java知识点干货总结,tomcat,spring,java)