• Springboot内置Tomcat线程数测试


    SpringBoot 2.7.3

    本文主要介绍SpringBoot内置Tomcat的主要参数,解析最大线程数和最大连接数的作用方式。SpringBoot各版本的参数配置可能不完全一样,本文以2.7.3版本为例进行试验。

    一、默认配置

    SpringBoot内置Tomcat的配置存放在 spring-configuration-metadata.json 文件中,配置以 server.tomcat 开头
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0RtFt2Av-1661699673372)(Springboot内置Tomcat线程数测试.assets/image-20220828210829288.png)]
    最小线程数
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4cVZXid1-1661699673376)(Springboot内置Tomcat线程数测试.assets/image-20220828211009723.png)]

    # 最小工作空闲线程数,默认10
    server.tomcat.threads.min-spare=10
    
    • 1
    • 2

    最大线程数
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LzRaehtK-1661699673377)(Springboot内置Tomcat线程数测试.assets/image-20220828211200274.png)]

    # 最大工作线程数,默认200
    server.tomcat.threads.max=200
    
    • 1
    • 2

    最大连接数
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BFeS1bvy-1661699673378)(Springboot内置Tomcat线程数测试.assets/image-20220828211746328.png)]

    # 最大连接数默认是8192
    server.tomcat.max-connections=8192
    
    • 1
    • 2

    队列长度
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ItAr312N-1661699673379)(Springboot内置Tomcat线程数测试.assets/image-20220828211712179.png)]

    # 等待队列长度,默认100
    server.tomcat.accept-count=100
    
    • 1
    • 2
    二、测试各参数的作用
    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";
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    2、Tomcat配置,这里设置小一点方便测试
    # 最小工作空闲线程数
    server.tomcat.threads.min-spare=10
    # 最大工作线程数
    server.tomcat.threads.max=20
    # 最大连接数
    server.tomcat.max-connections=30
    # 等待队列长度
    server.tomcat.accept-count=5
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    3、通过设置 Jmeter 线程的线程数据测试各参数的影响效果

    1)并发请求数 <= Tomcat最大线程数20

    Jmeter设置:线程数20
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-l3jrJGF8-1661699673380)(Springboot内置Tomcat线程数测试.assets/image-20220828214607910.png)]
    执行结果:平均响应时间为3s,20个请求都能正常处理
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nIyFyict-1661699673381)(Springboot内置Tomcat线程数测试.assets/image-20220828214639916.png)]
    2)并发请求数 >Tomcat最大线程数20

    Jmeter设置:线程数21
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yNivgcav-1661699673382)(Springboot内置Tomcat线程数测试.assets/image-20220828214416771.png)]
    执行结果:20个响应时间为3s,正常处理;1个请求响应时间为6s,说明Tomcat线程数不够,等待前面20个请求处理完,第21个请求才开始处理
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TgLLi3Z8-1661699673382)(Springboot内置Tomcat线程数测试.assets/image-20220828214444246.png)]
    3)请求数超过最大连接数30

    Jmeter设置:线程数31
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ruu7DNWC-1661699673383)(Springboot内置Tomcat线程数测试.assets/image-20220828220549385.png)]
    执行结果:31个请求全部执行成功,因为请求数31大于最大连接数30,所以第31个请求放入等待队列
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZmRvEyj9-1661699673383)(Springboot内置Tomcat线程数测试.assets/image-20220828220533735.png)]
    Jmeter设置:线程数36
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Y0n0NIGC-1661699673384)(Springboot内置Tomcat线程数测试.assets/image-20220828220828979.png)]
    执行结果:35个请求执行成功;一个执行失败,因为请求数大于了35(最大连接数30 + 等待队列5),请求被丢弃

    三、总结

    最大连接数:每个Http请求占用一个连接

    等待队列长度:Http请求数超过最大连接数时,多出的请求会放入等待队列,如果队列也满了请求会被丢弃。所以Tomcat能接收的请求数为最大连接数+等待队列长度

    最大线程数:Tomcat最多能同时处理的请求数,比如有30个请求,但是最大线程数为20,那么同时有20个请求可以被处理

    四、参考文档

    Jmeter教程(一) - 入门

  • 相关阅读:
    审计dvwa高难度命令执行漏洞的代码,编写实例说明如下函数的用法
    Vue原理及源码设计模式
    《2023人工智能发展白皮书》发布(118页)
    若依系统富文本框上传图片报错!
    【iptables 实战】02 iptables常用命令
    gRPC入门学习之旅(二)
    机器学习模型2——决策树
    go并发(进程、线程、协程)
    桥接模式(Bridge Pattern) C++
    矩阵的基础知识
  • 原文地址:https://blog.csdn.net/yaorongke/article/details/126576139