首页 > 其他分享 >Tomcat最大线程数、最大连接数、超时时间及高效配置

Tomcat最大线程数、最大连接数、超时时间及高效配置

时间:2022-12-06 18:35:22浏览次数:91  
标签:请求 Tomcat 排队 连接数 线程 maxConnections

一、前言

Tomcat 作为 Java Web 程序比较常用的 Servlet 容器实现,在 Web 开发中有比较重要的地位。

二、Tomcat使用的IO模式

Tomcat 有三种 IO 模式,BIO、NIO、APR。
在 Tomcat7 及以下 Linux 中默认启用的是 BIO 模式,Tomcat8 及以上使用的是 NIO 模式,利用 Java 的异步 IO 处理,可以通过少量的线程处理大量的连接请求。
除这两种方式外,还有一种 APR(Apache Portable Runtime) 模式,从操作系统层面解决 IO 阻塞问题。Tomcat7 或Tomcat8 在 Win7 或以上的系统中启动默认使用这种方式。
要注意的是,在 SpringBoot 内嵌的 Tomcat 不自动开启 APR 模式,需要手动进行配置。
可以通过启动日志看到 SpringBoot 中启用的 IO 模式:

2021-01-26 17:22:53.076  INFO 8604 --- [nio-9999-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2021-01-26 17:22:53.076  INFO 8604 --- [nio-9999-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2021-01-26 17:22:53.087  INFO 8604 --- [nio-9999-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 10 ms

关于 BIO、NIO、APR 的详解不做过多介绍。

三、Tomcat主要的配置参数

3.1 maxConnections 最大连接数

这个参数是指在同一时间,Tomcat 能够接受的最大连接数。对于 Java 的阻塞式 BIO,默认值是 maxthreads 的值;可以通过配置 Executor 执行器来修改这个值。
对于 Java 新的 NIO 模式,maxConnections 默认值是 10000。
对于 windows 上 APR/native IO模式,maxConnections 默认值为 8192,这是出于性能原因,如果配置的值不是 1024 的倍数,maxConnections 的实际值将减少到 1024 的最大倍数。
如果设置为 -1,则禁用 maxconnections 功能,表示不限制tomcat容器的连接数。

简单来说就是 Tomcat 总共允许建立多少连接。

3.2 maxThreads 最大线程数

每一次 Http 请求到达 Web 服务,Tomcat 都会创建一个线程来处理该请求,最大线程数决定了 Web 服务同时可以处理多少请求。maxThreads 默认值为 200,建议增加,但是增加线程是有成本的,更多的线程代表会有更多的上下文切换,也意味着 JVM 会分配更多的内存。

3.3 acceptCount 排队连接数

当 Tomcat 的最大连接数 maxConnections 被占满之后,后续的请求就会进行排队,排队的最大数量就是 acceptCount,举个例子,当前 maxConnections 为 10,acceptCount 为 5,并且 maxConnections 已经使用了 10,那么后续的请求就会排队,每来一个请求,acceptCount 就会 +1 ,当 acceptCount 增加到 5 ,在后续的请求就会被直接放弃。

3.4 connection-timeout 连接建立时间

HTTP 协议运行在 TCP 之上,所以每次请求到来,客户端和服务端会建立一次 TCP 连接,建立连接需要三次握手,所以就需要一定的时间,connection-timeout 限制了连接建立的时间,当建立连接时间超过这个值,连接就会建立失败。默认为 20000ms。

四、高效配置

常用配置:

server:
  tomcat:
    accept-count: 100
    threads:
      # 1核2g内存为200,4核8g内存为800
      max: 800
      # 最小空闲线程数量,保证线程池中一直有最少100个线程,防止流量激增
      min-spare: 100
    # 连接超时时间
    connection-timeout: 5000
    # 最大连接数,可以适应 APR 模式
    max-connections: 8192

五、通俗解释

我们可以把 Tomcat 比作餐厅,餐厅有排队取号区域,餐桌,厨房,厨师。

maxConnections 可以类比为餐桌数量,acceptCount 可以类比为排队取号队列长度,maxThreads 可以类比为厨房里厨师的数量。

当客人来的时候,如果餐桌数量没坐满,客人可以直接上餐桌点餐,点餐之后,厨师就会做这一桌的食物,一个厨师同时只能为一桌服务。

当客人来的时候,如果餐桌坐满了,就需要去排队取号区排队取号,如果取号区人也排满了,餐厅就会赶你走。

由于厨师数量可能少于餐桌的数量,所以会出现多个厨师负责多个餐桌的情乱,也就是线程数量不够,连接等待处理的情况。

六、简单的测试

SpringBoot 配置:

server:
  port: 9999
  tomcat:
    accept-count: 1
    threads:
      max: 10
      min-spare: 10
    connection-timeout: 100
    max-connections: 1

接口定义(模拟处理需要 5 秒):

1     @GetMapping("/tomcat-meter")
2     public R<?> tomcatMeter() throws InterruptedException {
3         TimeUnit.SECONDS.sleep(5);
4         return Resp.new200("this is tomcat meter");
5     }

使用 Jmeter 同时使用 50 个线程访问测试:

查看测试报告:

测试结果:
只有两个请求请求成功,因为最大连接数为1 ,排队数量为 1,所以最多只能处理两个请求,其余的 48 个请求直接被丢弃。



标签:请求,Tomcat,排队,连接数,线程,maxConnections
From: https://www.cnblogs.com/fnlingnzb-learner/p/16957037.html

相关文章

  • springboot2 搭建日志收集系统存入mongodb + redis+mq+线程池+xxljobs
    我们看到了高效批量插入mongodb速度还不错,那么我们的系统日志收集怎么做呢。当然当前文件日志收集效果也不错,比如前面博文写的elkf搭建日志收集系统。但我们系统中总是有......
  • java线程研究---(6)暂停Thread:join
    暂停Threadjoin方法,会让线程线程暂停,具体如下:调用方法:Thread对象.join()比如,当前有一个线程对象son,当调用了son.join()方法之后(不是child.start()方法哦),会让线程对象son的父......
  • 剖析java中几种创建线程的几种方式
    文章目录​​继承Thread​​​​实现Runnable接口​​​​实现Callable接口​​​​newThread方式的缺点​​​​通过线程池创建​​​​newSingleThreadExecutor​​​​n......
  • JAVA 实现多线程发售火车票
    publicclassdemo05{publicstaticvoidmain(String[]args){TicketWindowtw=newTicketWindow();newThread(tw,"窗口1").start();ne......
  • 多线程之创建线程
    多线程进程在操作系统中运行的程序就是进程,进程就是执行程序的一次执行过程,它是一个动态的概念式系统资源分配的单位通常再一个进程中可以包含若干个线程,当然一个进程......
  • [C++11与并发编程]7、本地变量线程安全
    本地变量线程安全layout:posttitle:本地变量线程安全categories:cpp_concurrencydescription:C++并发编程简介keywords:c++,并发编程,本地变量线程安全​本地变量......
  • 线程池
    Executor框架集图ExecutorServicejuc.ExecutorService继承自Executor接口ThreadPoolExecutor成员变量:ctl://表示两种含义://①:workerCount:worker计数,表示正在......
  • jdk自带的javaVisualVM检测tomcat
    背景:在项目运行的过程中想了解一下tomcat的执行性能情况,下面以jdk自带的javaVisualVm为例进行配置检测1.在我本地(windows系统)找到jdk中的bin目录,找到jvisualvm.exe双击......
  • 线程池原理
    (92条消息)一文读懂线程池的实现原理_老周聊架构的博客-CSDN博客_线程池原理 博客下载学习社区GitCode云服务猿如意  搜索会员中心 <img......
  • Spring中获取request的几种方法,及其线程安全性分析
    前言本文将介绍在SpringMVC开发的web系统中,获取request对象的几种方法,并讨论其线程安全性。目录概述如何测试线程安全性方法1:Controller中加参数方法2:自动注入方法3......