[Spring Boot]用Jmeter测试maxConnections、maxThreads、acceptCount的关系

Spring Boot内置Tomcat有三个重要参数:maxConnections、maxThreads、acceptCount。

(以Tomcat9.0为例,参考链接:https://tomcat.apache.org/tomcat-9.0-doc/config/ajp.html)
maxConnections:最大连接数,默认是10000。好比说办银行业务要预约,一天最多预约10000个号。
maxThreads:最大线程数,默认是200。好比银行柜台,排队排多长没用,真正能处理业务的是柜台。
acceptCount:最大排队数,默认是100。预约了号的人,在真正办业务之前,还要排队。当然,排队的顺序是按预约顺序来,先预约先排队。

OK,下面来验证一下这几个参数的作用。

先生成一个Spring Boot应用,提供一个访问接口。

package com.bill;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class ClientController {

	@Value("${server.port}")
	private int port;
	
    @RequestMapping(value = "/info", method = RequestMethod.GET)
    public String info() {
    	try {
    			// 这里我们让程序等候20秒,目的是触发spring.mvc.async.request-timeout这个配置
			Thread.sleep(20000);
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
        return "hello,"+port;
    }
}

application.properties中设置:

server.port=8763
#连接超过20秒则返回Connection refused
spring.mvc.async.request-timeout=20000
#最多接收10个请求
server.tomcat.max-connections=10
#同时只能处理2个请求
server.tomcat.max-threads=2
#并发数到达max-threads后,允许2个请求进行排队等候
server.tomcat.accept-count=2

OK,上JMeter。开20个线程数,连接超时时间10秒,响应超时时间30秒。
[Spring Boot]用Jmeter测试maxConnections、maxThreads、acceptCount的关系_第1张图片
[Spring Boot]用Jmeter测试maxConnections、maxThreads、acceptCount的关系_第2张图片

[Spring Boot]用Jmeter测试maxConnections、maxThreads、acceptCount的关系_第3张图片
测试结果:
[Spring Boot]用Jmeter测试maxConnections、maxThreads、acceptCount的关系_第4张图片
[Spring Boot]用Jmeter测试maxConnections、maxThreads、acceptCount的关系_第5张图片
可以看出:
第1秒:8个请求得到响应数据:Connection refused connect
第20秒:2个请求正常响应
第30秒:剩余10个请求得到响应数据:Read timed out

你可能感兴趣的:(Java,spring,boot,spring,cloud,JMeter)