SpringBoot 2.7.3
本文主要介绍SpringBoot
内置Tomcat
的主要参数,解析最大线程数和最大连接数的作用方式。SpringBoot
各版本的参数配置可能不完全一样,本文以2.7.3
版本为例进行试验。
一、默认配置
SpringBoot
内置Tomcat
的配置存放在 spring-configuration-metadata.json
文件中,配置以 server.tomcat
开头
最小线程数
# 最小工作空闲线程数,默认10
server.tomcat.threads.min-spare=10
最大线程数
# 最大工作线程数,默认200
server.tomcat.threads.max=200
最大连接数
# 最大连接数默认是8192
server.tomcat.max-connections=8192
队列长度
# 等待队列长度,默认100
server.tomcat.accept-count=100
二、测试各参数的作用
1、准备测试接口
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* Tomcat测试类
*
* @author Administrator
* @date 2022/8/28
*/
@RestController
@RequestMapping("/tomcat")
public class TomcatController {
/**
* localhost:8080/tomcat/getString
*
* @return
*/
@RequestMapping("/getString")
public String getString() {
try {
// 将线程挂起3秒,方便观察结果
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return "success";
}
}
2、Tomcat
配置,这里设置小一点方便测试
# 最小工作空闲线程数
server.tomcat.threads.min-spare=10
# 最大工作线程数
server.tomcat.threads.max=20
# 最大连接数
server.tomcat.max-connections=30
# 等待队列长度
server.tomcat.accept-count=5
3、通过设置 Jmeter
线程的线程数据测试各参数的影响效果
1)并发请求数 <= Tomcat
最大线程数20
Jmeter
设置:线程数20
执行结果:平均响应时间为3s,20个请求都能正常处理
2)并发请求数 >Tomcat
最大线程数20
Jmeter
设置:线程数21
执行结果:20个响应时间为3s,正常处理;1个请求响应时间为6s,说明Tomcat
线程数不够,等待前面20个请求处理完,第21个请求才开始处理
3)请求数超过最大连接数30
Jmeter
设置:线程数31
执行结果:31个请求全部执行成功,因为请求数31大于最大连接数30,所以第31个请求放入等待队列
Jmeter
设置:线程数36
执行结果:35个请求执行成功;一个执行失败,因为请求数大于了35(最大连接数30 + 等待队列5),请求被丢弃
三、总结
最大连接数:每个Http
请求占用一个连接
等待队列长度:Http
请求数超过最大连接数时,多出的请求会放入等待队列,如果队列也满了请求会被丢弃。所以Tomcat
能接收的请求数为最大连接数+等待队列长度
。
最大线程数:Tomcat
最多能同时处理的请求数,比如有30个请求,但是最大线程数为20,那么同时有20个请求可以被处理