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会尝试将请求放入到等待队列中。如果等待队列也满了,并且达到了最大线程数的限制,那么新的请求就会被拒绝。除此外,如果最大请求数超出限制,就算线程池和等待队列有空间也会拒绝请求。

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

相关推荐
Bug退退退123几秒前
RabbitMQ 工作模式
java·分布式·rabbitmq
小莫分享1 小时前
github 镜像节点
java
链上Sniper1 小时前
智能合约状态快照技术:实现 EVM 状态的快速同步与回滚
java·大数据·linux·运维·web3·区块链·智能合约
缘来是庄2 小时前
设计模式之建造者模式
java·设计模式·建造者模式
小湘西2 小时前
Apache HttpClient 的请求模型和 I/O 类型
java·http·apache
沃夫上校2 小时前
Feign调Post接口异常:Incomplete output stream
java·后端·微服务
q567315233 小时前
Java Selenium反爬虫技术方案
java·爬虫·selenium
张小洛3 小时前
Spring IOC容器核心阶段解密:★Bean实例化全流程深度剖析★
java·后端·spring·ioc容器·bean实例化
不良手残3 小时前
IDEA类和方法注释模板设置-保姆教程
java·开发语言
GoodStudyAndDayDayUp3 小时前
调用海康API预览视频
java·海康