iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >springboot内置tomcat支持最大的并发量问题怎么解决
  • 381
分享到

springboot内置tomcat支持最大的并发量问题怎么解决

2023-07-05 11:07:28 381人浏览 泡泡鱼
摘要

这篇文章主要介绍“SpringBoot内置Tomcat支持最大的并发量问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“springboot内置tomcat支持最大的并发量问题怎么解决”文章

这篇文章主要介绍“SpringBoot内置Tomcat支持最大的并发量问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“springboot内置tomcat支持最大的并发量问题怎么解决”文章能帮助大家解决问题。

    springboot内置的tomcat支持最大的并发量

    SpringBoot内置Tomcat,在默认设置中,Tomcat的最大线程数是200,最大连接数是10000。支持的并发量是指连接数,也就是说 支持最大并发量是一万(默认)

    Tomcat有两种处理连接的模式

    1,是Bio,一个线程只处理一个Socket连接,

    2,是NIO,一个线程处理多个Socket连接。

    由于Http请求不会太耗时,而且多个连接一般不会同时来消息,所以一个线程处理多个连接没有太大问题。一个线程处理多个连接数会很慢 有可能会超时

    默认内嵌Tomcat配置

    • server.tomcat.accept-count:等待队列长度,当可分配的线程数全部用完之后,后续的请求将进入等待队列等待,等待队列满后则拒绝处理,默认100。

    • server.tomcat.max-connections:最大可被连接数,默认10000

    • server.tomcat.max-threads:最大工作线程数,默认200,

    • server.tomcat.min-spare-threads:最小工作线程数,初始化分配线程数,默认10

    默认配置下,连接超过10000后会出现拒绝连接情况

    默认配置下,触发的请求超过200+100后拒绝处理(最大工作线程数+等待队列长度)

    如果默认配置无法满足当前需求 可以自己调优 可以手动修改配置来进行处理并发

    修改pro文件

    server.port=7001server.tomcat.accept-count=1000server.tomcat.max-connections=10000server.tomcat.max-threads=500server.tomcat.min-spare-threads=100

    然后 打包重启项目

    kill -9 9545   //杀死进程

    ps -ef | grep java   //查看项目启动的端口

    pstree -p 7968 | wc -l    //查看进程数

    我们也可以使用配置文件, 可以新增WEBServerConfiguration.java文件

    import org.apache.catalina.connector.Connector;import org.apache.coyote.http11.Http11NioProtocol;import org.springframework.boot.web.embedded.tomcat.TomcatConnectorCustomizer;import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;import org.springframework.boot.web.server.ConfigurableWebServerFactory;import org.springframework.boot.web.server.WebServerFactoryCustomizer;import org.springframework.stereotype.Component;//当Spring容器内没有TomcatEmbeddedServletContainerFactory这个bean时,会吧此bean加载进spring容器中@Componentpublic class WebServerConfiguration implements WebServerFactoryCustomizer<ConfigurableWebServerFactory> {    @Override    public void customize(ConfigurableWebServerFactory configurableWebServerFactory) {            //使用对应工厂类提供给我们的接口定制化我们的tomcat connector        ((TomcatServletWebServerFactory)configurableWebServerFactory).addConnectorCustomizers(new TomcatConnectorCustomizer() {            @Override            public void customize(Connector connector) {                Http11NioProtocol protocol = (Http11NioProtocol) connector.getProtocolHandler();                //定制化keepalivetimeout,设置30秒内没有请求则服务端自动断开keepalive链接                protocol.seTKEepAliveTimeout(30000);                //当客户端发送超过10000个请求则自动断开keepalive链接                protocol.setMaxKeepAliveRequests(10000);            }        });    }}

    备注:

    MySQL 数据库 QPS 容量问题:

    • 主键查询: 千万级别数据 == 1-10 ms

    • 唯一索引查询: 千万级别数据 == 10-100 ms

    • 非唯一索引查询: 千万级别数据 == 100-1000ms

    • 无索引数据: 百万级别数据 == 1000ms+

    MySQL 数据库 TPS 容量问题:

    • 非插入的更新删除操作: 同查询

    • 插入操作: 1w~10w tps(依赖配置优化)

    提高tomcat并发量的几种方法

    Apache + Tomcat 结合起来用Apache负责静态页面,Tomcat负责动态页面,同时减少connectionTimeout的时间,以应对并发量大线程回收来不及的情况。

    压力过大的问题,可以做负载均衡,一个TOMCAT无论如何也不可能担当如此多的线程负载,而且JVM过大,其内存管理成本将显著加大。2G的内存,做3-4个TOMCAT实例(512RAM*4),更为科学合理。

    数据库连接池,不少人,都推荐使用C3P0,能提高访问数据库的并发性能好几倍。

    采用Tomcat集群可以最大程度的发挥服务器的性能,可以在配置较高的服务器上部署多个Tomcat,也可以在多台服务器上分别部署Tomcat,Apache和Tomcat整合的方式还是JK方式。经过验证,系统对大用户量使用的响应方面,Apache+3Tomccat集群> Apache+2Tomcat集群 > Apache集成Tomcat > 单个Tomcat。并且采用Apache+多Tomcat集群的部署方式时,如果一个Tomcat出现宕机,系统可以继续使用,所以在硬件系统性能足够优越的情况下,需要尽量发挥软件的性能,可以采用增加Tomcat集群的方式。

    设置MPM(Multi Processing Modules多道处理模块)。ThreadPerChild,这个参数用于设置每个进程的线程数,在windows环境下默认值是64,最大值是1920,建议设置为100-500之间,服务器性能高的话值大一些,反之小一些。MaxRequestPerChild表示每个子进程能够处理的最大请求数。这个参数的值更大程度上取决于服务器的内存,如果内存比较大的话可以设置为很大的参数,否则设置一个较小的值,建议值是3000.

    关闭DNS和名字解析 HostnameLookups off

    打开UseCanonicalName模块 UseCanonicalName on

    关闭多余模块 一般来说,不需要加载的模块有,mod_include.so、mod_autoindex.so、mod_access.so、mod_auth.so.

    打开KeepAlive支持

    KeepAlive on, KeepAliveTimeout 15 MaxKeepAliveRequests 1000

    根据实际经验,通过Apache和Tomcat集群的方式提高系统性能的效果十分明显,这种方式可以最大化的利用硬件资源,通过多个Tomcat的处理来分担单Tomcat时的压力。

    web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,linux是1000个左右。

    关于“springboot内置tomcat支持最大的并发量问题怎么解决”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

    --结束END--

    本文标题: springboot内置tomcat支持最大的并发量问题怎么解决

    本文链接: https://www.lsjlt.com/news/351422.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • springboot内置tomcat支持最大的并发量问题怎么解决
      这篇文章主要介绍“springboot内置tomcat支持最大的并发量问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“springboot内置tomcat支持最大的并发量问题怎么解决”文章...
      99+
      2023-07-05
    • springboot内置的tomcat支持最大的并发量问题
      目录springboot内置的tomcat支持最大的并发量Tomcat有两种处理连接的模式默认内嵌Tomcat配置提高tomcat并发量的几种方法总结springboot内置的tom...
      99+
      2023-03-12
      springboot内置tomcat springboot最大并发量 springboot并发量
    • 解决SpringBoot内嵌Tomcat并发容量的问题
      一、SpringBoot内嵌Tomcat默认配置与优化 在做一个关于秒杀系统的模块,进行Jmeter压测性能的时候发现tomcat并发上不去,深入原因找到可供优化的地方,力求最大性能...
      99+
      2024-04-02
    • springboot最大并发量怎么配置
      在Spring Boot中,可以通过配置服务器的线程池来调整最大并发量。具体配置方式取决于你使用的服务器。以下是针对一些常见服务器的...
      99+
      2023-10-11
      springboot
    • tomcat高并发阻塞问题怎么解决
      要解决Tomcat高并发阻塞问题,可以考虑以下几个方面:1. 调整Tomcat配置:增加Tomcat的线程池大小、调整连接超时时间等...
      99+
      2023-10-12
      tomcat
    • springboot多线程高并发问题怎么解决
      要解决Spring Boot多线程高并发问题,你可以考虑以下几个方面:1. 线程池配置:合理配置线程池的大小、队列容量等参数,以满足...
      99+
      2023-08-24
      springboot
    • Ubuntu安装Tomcat并配置systemctl管理的问题怎么解决
      这篇“Ubuntu安装Tomcat并配置systemctl管理的问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“U...
      99+
      2023-06-30
    • 怎么解决springdataJPA对原生sql支持的问题
      这篇文章主要为大家展示了“怎么解决springdataJPA对原生sql支持的问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么解决springdataJPA对原生sql支持的问题”这篇文章...
      99+
      2023-06-15
    • Mysql怎么数据库平滑扩容解决高并发和大数据量问题
      本篇内容主要讲解“Mysql怎么数据库平滑扩容解决高并发和大数据量问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Mysql怎么数据库平滑扩容解决高并发和大数据量问题”吧!1 停机方案发布公告...
      99+
      2023-06-30
    • redis怎么解决库存并发问题实现数量控制
      本篇内容介绍了“redis怎么解决库存并发问题实现数量控制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!redis是单进程,阻塞式,在同一时...
      99+
      2023-06-29
    • 超出MySQL最大连接数的问题怎么解决
      今天小编给大家分享的是超出MySQL最大连接数的问题怎么解决,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。超出MySQL最大连接数问题如果遇到MySQ连接数超出最大限制了,不要慌,往...
      99+
      2023-07-06
    • 怎么解决兼容IE6\7\8不支持html5标签的问题
      小编给大家分享一下怎么解决兼容IE6\7\8不支持html5标签的问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! html5大行其道的时代已经到来。如果你...
      99+
      2024-04-02
    • Python中最强大的错误重试库问题怎么解决
      本文小编为大家详细介绍“Python中最强大的错误重试库问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python中最强大的错误重试库问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1 简...
      99+
      2023-06-30
    • Linux多线程及多线程并发访问同一块内存的问题怎么解决
      这篇文章主要介绍了Linux多线程及多线程并发访问同一块内存的问题怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Linux多线程及多线程并发访问同一块内存的问题怎么解决文章都会有所收获,下面我们一起来看...
      99+
      2023-07-05
    • MySQL事务的ACID特性及并发问题怎么解决
      这篇“MySQL事务的ACID特性及并发问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL事务的ACID特...
      99+
      2023-07-02
    • Go怎么使用sync.Map来解决map的并发操作问题
      这篇文章主要介绍“Go怎么使用sync.Map来解决map的并发操作问题”,在日常操作中,相信很多人在Go怎么使用sync.Map来解决map的并发操作问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Go怎...
      99+
      2023-06-25
    • 怎么解决XP共享打印机连接超过最大值的问题
      本篇内容主要讲解“怎么解决XP共享打印机连接超过最大值的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决XP共享打印机连接超过最大值的问题”吧!最近一个朋友的公司的网络打印共享打印出问...
      99+
      2023-06-14
    • 怎么解决Element的穿梭框数据量大时点击全选卡顿问题
      本篇内容介绍了“怎么解决Element的穿梭框数据量大时点击全选卡顿问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!现象:我们渲染了999...
      99+
      2023-06-25
    • 怎么解决Linux开启snmp监控后大量Received SNMP packet(s) from UDP的问题
      这篇文章主要介绍“怎么解决Linux开启snmp监控后大量Received SNMP packet(s) from UDP的问题”,在日常操作中,相信很多人在怎么解决Linux开启snmp监控后大量Received SNMP packet(...
      99+
      2023-06-13
    • 怎么解决layui前端框架form表单,table表等内置控件不显示的问题
      这篇文章将为大家详细讲解有关怎么解决layui前端框架form表单,table表等内置控件不显示的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。使用form表单前需要...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作