当前位置:   article > 正文

Springboot内置tomcat优化_springboot 优化tomcat

springboot 优化tomcat

目录

一、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;

  1. # Tomcat
  2. server:
  3. tomcat:
  4. uri-encoding: UTF-8
  5. #最小线程数
  6. min-spare-threads: 100
  7. #最大线程数
  8. max-threads: 800
  9. #最大链接数
  10. max-connections: 10000
  11. #最大等待队列长度
  12. accept-count: 1000
  13. #请求头最大长度kb
  14. max-http-header-size: 1048576
  15. #请求体最大长度kb、不限制 POST 大小需要将值设置为 -1
  16. max-http-post-size: 2097152
  17. #服务http端口
  18. port: 8090
  19. #链接建立超时时间
  20. connection-timeout: 3000
  21. servlet:
  22. #配置context-path,访问时,需要在连接后加上配置的路径 localhost:8888/server
  23. 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的设置,详见一下代码

  1. /**
  2. * @author swadian
  3. * @date 2021/11/17
  4. * @Version 1.0
  5. * @describetion 当Spring容器内没有TomcatEmbeddedServletContainerFactory這個bean时加载
  6. */
  7. @Component
  8. public class WebServerConfiguration implements WebServerFactoryCustomizer<ConfigurableWebServerFactory> {
  9. @Override
  10. public void customize(ConfigurableWebServerFactory configurableWebServerFactory) {
  11. //使用对应工厂类提供给我们的接口定制化我们的tomcat connector
  12. ((TomcatServletWebServerFactory) configurableWebServerFactory).addConnectorCustomizers(
  13. (connector) -> {
  14. Http11NioProtocol protocol = (Http11NioProtocol) connector.getProtocolHandler();
  15. //定制化keepalivetimeout,设置30秒内没有请求则服务端自动断开keepalive链接
  16. protocol.setKeepAliveTimeout(30000);
  17. //当客户端发送超过10000个请求则自动断开keepalive链接
  18. protocol.setMaxKeepAliveRequests(10000);
  19. }
  20. );
  21. }
  22. }
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/52542
推荐阅读
相关标签
  

闽ICP备14008679号