目录

一、spring-configuration-metadata.json内置tomcat优化

1、常用配置说明

2、springboot中的配置文件

二、keepalive链接设置


一、spring-configuration-metadata.json内置tomcat优化

1、常用配置说明

我们在使用springboot开发web项目时,大多数时候采用的是内置的Tomcat(当然也可以配置支持内置的jetty),内置Tomcat有什么好处呢?

  1. 方便微服务部署,减少繁杂的配置
  2. 方便项目启动,不需要单独下载web容器,如Tomcat,jetty等。

针对目前的容器优化,可以从以下几点考虑:

1、线程数  2、超时时间  3、JVM优化

首先,线程数是一个重点,每一次HTTP请求到达Web服务器,Web服务器都会创建一个线程来处理该请求,该参数决定了应用服务同时可以处理多少个HTTP请求。

比较重要的有两个:初始线程数最大线程数

  • 初始线程数:保障启动的时候,如果有大量用户访问,能够很稳定的接受请求
  • 最大线程数:用来保证系统的稳定性
  • 超时时间:用来保障连接数不容易被压垮。如果大批量的请求过来,延迟比较高,很容易把线程数用光,这时就需要提高超时时间。这种情况在生产中是比较常见的 ,一旦网络不稳定,宁愿丢包也不能把服务器压垮

min-spare-threads:最小备用线程数,tomcat启动时的初始化的线程数。默认10

max-threads:Tomcat可创建的最大的线程数,每一个线程处理一个请求,超过这个请求数后,客户端请求只能排队,等有线程释放才能处理。建议这个配置数可以在服务器CUP核心数的200~250倍之间)默认200

accept-count:当调用Web服务的HTTP请求数达到tomcat的最大线程数时,还有新的HTTP请求到来,这时tomcat会将该请求放在等待队列中,这个acceptCount就是指能够接受的最大等待数默认100。如果等待队列也被放满了,这个时候再来新的请求就会被tomcat拒绝(connection refused)。

max-connections:这个参数是指在同一时间,tomcat能够接受的最大连接数。一般这个值要大于(max-threads)+(accept-count)。(最大线程数+排队数)

connection-timeout:最长等待时间,如果没有数据进来,等待一段时间后断开连接,释放线程。

2、springboot中的配置文件

spring-configuration-metadata.json文件中的tomcat配置信息

 对于具体配置类ServerProperties,我们可以看到对于tomcat的配置有很多,可以根据自己的需要进行选择配置

操作:在spring boot配置文件中application.yml,添加以下配置

这块对tomcat进行了一个简单优化配置,最大工作线程数是800,最小工作线程是100,超时时间是3000ms;

# Tomcat
server:
  tomcat:
    uri-encoding: UTF-8
    #最小线程数
    min-spare-threads: 100
    #最大线程数
    max-threads: 800
    #最大链接数
    max-connections: 10000
    #最大等待队列长度
    accept-count: 1000
    #请求头最大长度kb
    max-http-header-size: 1048576
    #请求体最大长度kb、不限制 POST 大小需要将值设置为 -1
    max-http-post-size: 2097152
  #服务http端口
  port: 8090
  #链接建立超时时间
  connection-timeout: 3000
  servlet:
    #配置context-path,访问时,需要在连接后加上配置的路径 localhost:8888/server
    context-path: /server

注:以上是4核8G服务器的经验配置,合适的配置还需要根据具体的压测结果来验证

springboot内置tomcat优化其他参考文档

spring boot (八) 内置tomcat配置和优化 - AlexZS - 博客园一、 在application.properties文件中配置 二、实现 WebServerFactoryCustomizer 接口 1、 2、 同时springboot支持jetty pom文件要加https://www.cnblogs.com/alomsc/articles/10841563.html

10-SpringBoot定制和优化内嵌Tomcat - Spring Boot 学习笔记 - 文江博客10.1 配置日志 10.1.1 在配置文件中配置 在application.properties中添加 server.tomcat.accesslog.enabled=true server.tomcat.accesslog.direct…https://www.wenjiangs.com/doc/8srgq76ySpringboot内置tomcat优化说明_GaoChenXi-CSDN博客修改springboot内置tomcatEmbeddedServletContainerCustomizer接口中的抽象方法有三个内置容器public interface EmbeddedServletContainerCustomizer {/** * Customize the specified {@link ConfigurableEmbeddedServletContaine...https://blog.csdn.net/gcxzflgl/article/details/80543540

Tomcat-8 性能监控及调优 - 破解孤独 - 博客园一、下载地址 https://tomcat.apache.org/download-80.cgi 二、安装步骤 将安装包 apache-tomcat-8.5.39.tar.gz 上传至服务器https://www.cnblogs.com/L-Test/p/10611126.html

二、keepalive链接设置

我们发现,spring-configuration-metadata.json文件中并没有keepalive的相关配置参数,而合理的设置这个参数,往往能帮我们节省很多不必要的性能开销,对于keepalive的设置,详见一下代码

/**
 * @author swadian
 * @date 2021/11/17
 * @Version 1.0
 * @describetion 当Spring容器内没有TomcatEmbeddedServletContainerFactory這個bean时加载
 */
@Component
public class WebServerConfiguration implements WebServerFactoryCustomizer<ConfigurableWebServerFactory> {
    @Override
    public void customize(ConfigurableWebServerFactory configurableWebServerFactory) {
        //使用对应工厂类提供给我们的接口定制化我们的tomcat connector
        ((TomcatServletWebServerFactory) configurableWebServerFactory).addConnectorCustomizers(
                (connector) -> {
                    Http11NioProtocol protocol = (Http11NioProtocol) connector.getProtocolHandler();
                    //定制化keepalivetimeout,设置30秒内没有请求则服务端自动断开keepalive链接
                    protocol.setKeepAliveTimeout(30000);
                    //当客户端发送超过10000个请求则自动断开keepalive链接
                    protocol.setMaxKeepAliveRequests(10000);
                }
        );
    }
}
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐