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

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

相关推荐
在努力的前端小白2 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
一叶飘零_sweeeet5 小时前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8
艾伦~耶格尔5 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
一只叫煤球的猫5 小时前
🕰 一个案例带你彻底搞懂延迟双删
java·后端·面试
最初的↘那颗心5 小时前
Flink Stream API 源码走读 - print()
java·大数据·hadoop·flink·实时计算
JH30736 小时前
Maven的三种项目打包方式——pom,jar,war的区别
java·maven·jar
带刺的坐椅7 小时前
轻量级流程编排框架,Solon Flow v3.5.0 发布
java·solon·workflow·flow·solon-flow
David爱编程8 小时前
线程调度策略详解:时间片轮转 vs 优先级机制,面试常考!
java·后端
阿冲Runner8 小时前
创建一个生产可用的线程池
java·后端
写bug写bug8 小时前
你真的会用枚举吗
java·后端·设计模式