Tomcat调优相关理解

什么是QPS?

是Queries Per Second 的缩写,是指服务器每秒查询数,比如定义一个a接口,该接口是10QPS,那么就是指该接口每秒可以处理10个请求

springboot默认并发处理数是多少?

springboot并发处理要看servlet容器,而servlet容器默认是Tomcat,而Tomcat容器可以处理的并发请求数主要受到最大线程数(max-threads)的限制,Tomcat的默认最大线程数通常是200,这意味着在默认情况下,SpringBoot应用可以同时处理200个并发请求。

Tomcat主要配置参数

**最大连接数(max-connections):**Tomcat可以处理的最大请求数量。超过这个数量的请求会被放入到等待队列中。在SpringBoot的某些版本中,这个默认值可能是10000或8192,具体取决于SpringBoot和Tomcat的版本。

**等待队列长度(accept-count):**当所有可能的请求处理线程都在使用中时,传入连接请求的最大队列长度。在默认情况下,这个值通常是100。当等待队列也满了之后,新的请求会被拒绝。

**最小工作线程数(min-spare-threads):**Tomcat启动时创建的线程数,也是线程池中最小的线程数。这个值通常设置为较小的数字,以确保在并发请求较少时不会浪费资源。在默认情况下,这个值可能是10或更小。

**最大工作线程数(max-spare-threads):**刚才已经说了。默认200,具体默认多少,可能版本不同 ,本文只是作为帮助快速大概对Tomcat的调优相关理解。

从上文得出疑问

最大工作线程数和最大连接数什么关系?

可以根据Tomcat的不同IO模型来理解:

在BIO模型下

最大线程数和最大请求数量是相等的,因为每个连接都需要一个线程来处理。 在

NIO和NIO2模型下

最大线程数和最大请求数量可以不同。最大线程数仍然表示Tomcat能够同时处理的最大请求线程数量,而最大请求数量则表示Tomcat能够同时接受的网络连接的最大数量。由于NIO和NIO2模型采用了更高效的I/O处理方式,因此最大请求数量可以远大于最大线程数。

关于等待队列和最大请求数量的关系?

1、等待队列的长度和最大请求数量是两个不同的配置参数,它们之间没有直接的依赖关系。

2、等待队列的长度限制了当所有线程都在忙碌时,Tomcat能够暂时存储的额外请求数量。

3、最大请求数量则限制了Tomcat能够同时接受的网络连接的最大数量。

4、因此,即使最大请求数量设置为10000,当所有线程都在忙碌且等待队列也满了之后,新的请求仍然会被拒绝,并返回一个错误响应给客户端。这个错误通常是一个HTTP 503状态码。

5、当前活跃的连接数已经达到了最大请求数限制,那么即使线程池和等待队列还有空间,Tomcat也会拒绝新的连接尝试。

Tomcat线程池的工作机制

Tomcat的线程池在处理并发请求时,首先会使用核心线程数(即最小工作线程数)来处理请求。当核心线程数都在忙碌时,如果有新的请求到来,Tomcat会尝试将请求放入到等待队列中。如果等待队列也满了,并且达到了最大线程数的限制,那么新的请求就会被拒绝。除此外,如果最大请求数超出限制,就算线程池和等待队列有空间也会拒绝请求。

==========后续还会对本文进行完善或修改部分内容===========

相关推荐
RainbowSea15 小时前
12. LangChain4j + 向量数据库操作详细说明
java·langchain·ai编程
RainbowSea15 小时前
11. LangChain4j + Tools(Function Calling)的使用详细说明
java·langchain·ai编程
考虑考虑19 小时前
Jpa使用union all
java·spring boot·后端
用户37215742613520 小时前
Java 实现 Excel 与 TXT 文本高效互转
java
浮游本尊21 小时前
Java学习第22天 - 云原生与容器化
java
渣哥1 天前
原来 Java 里线程安全集合有这么多种
java
间彧1 天前
Spring Boot集成Spring Security完整指南
java
间彧1 天前
Spring Secutiy基本原理及工作流程
java
Java水解1 天前
JAVA经典面试题附答案(持续更新版)
java·后端·面试
洛小豆1 天前
在Java中,Integer.parseInt和Integer.valueOf有什么区别
java·后端·面试