springboot内置tomcat并发多少
SpringBoot内置Tomcat,在默认设置中,Tomcat的最大线程数是200,最大连接数是10000。支持的并发量是指连接数。
Tomcat有两种处理连接的模式,一种是BIO,一个线程只处理一个连接,另一种就是NIO,一个线程处理多个连接。由于HTTP请求不会太耗时,而且多个连接一般不会同时来消息,所以一个线程处理多个连接没有太大问题。因此,200个线程处理10000条连接完全ok。
默认值可以在spring-boot-autoconfigure-x.x.x 包中看到。
微服务并发量最高支持多少
要看服务器配置。
SpringBoot能支持的最大并发量主要看其对内置服务器的设置。
由于现在都使用的是springboot服务,配置文件中也没有配置相关参数,基本都是使用默认的线程配置。
如何配置Spring Boot内嵌的tomcat8的最大线程数,最大连接数
tomcat最大线程数的设置
Tomcat的server.xml中连接器设置如下
Connector port="8080"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
debug="0" connectionTimeout="20000"
disableUploadTimeout="true" /
Connector port="8080"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
debug="0" connectionTimeout="20000"
disableUploadTimeout="true" /
tomcat在配置时设置最大线程数,当前线程数超过这个数值时会出错,那么有没有办法捕获到这个错误,从而在client端显示出错信息?
2. 如何加大tomcat连接数
在tomcat配置文件server.xml中的Connector /配置中,和连接数相关的参数有:
minProcessors:最小空闲连接线程数,用于提高系统处理性能,默认值为10
maxProcessors:最大连接线程数,即:并发处理的最大请求数,默认值为75
acceptCount:允许的最大连接数,应大于等于maxProcessors,默认值为100
enableLookups:是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
connectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
其中和最大连接数相关的参数为maxProcessors和acceptCount。如果要加大并发连接数,应同时加大这两个参数。
web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。tomcat5中的配置示例:
Connector port="8080"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
debug="0" connectionTimeout="20000"
disableUploadTimeout="true" /
对于其他端口的侦听配置,以此类推。
3. tomcat中如何禁止列目录下的文件
在{tomcat_home}/conf/web.xml中,把listings参数设置成false即可,如下:
init-param
param-namelistings/param-name
param-valuefalse/param-value
/init-param
init-param
param-namelistings/param-name
param-valuefalse/param-value
/init-param
4.如何加大tomcat可以使用的内存
tomcat默认可以使用的内存为128MB,在较大型的应用项目中,这点内存是不够的,需要调大。
Unix下,在文件{tomcat_home}/bin/catalina.sh的前面,增加如下设置:
JAVA_OPTS='-Xms【初始化内存大小】 -Xmx【可以使用的最大内存】'
需要把这个两个参数值调大。例如:
JAVA_OPTS='-Xms256m -Xmx512m'
表示初始化内存为256MB,可以使用的最大内存为512MB
SpringBoot 整合线程池及各参数详解
ThreadPoolConfig
ThreadController
AsyncService
AsyncServiceImpl
application.yaml
运行结果
参数默认值及含义
对照源码解析,可以得出以下结论:
1.如果线程池中线程数量 核心线程数,新建一个线程执行任务;
2.如果线程池中线程数量 = 核心线程数,则将任务放入任务队列
3.如果线程池中线程数量 = 核心线程数 且 maxPoolSize,且任务队列满了,则创建新的线程;
4.如果线程池中线程数量 核心线程数,当线程空闲时间超过了keepalive时,则会销毁线程;由此可见线程池的队列如果是无界队列,那么设置线程池最大数量是无效的;
5.如果线程池中的任务队列满了,而且线程数达到了maxPoolSize,并且没有空闲的线程可以执行新的任务,这时候再提交任务就会执行拒绝策略
拒绝策略详解
拒绝策略RejectedExecutionHandler分为以下5种
结论
这几种策略没有好坏之分,只是适用不同场景,具体哪种合适根据具体场景和业务需要选择,如果需要特殊处理就自己定义好了。
springboot接口的响应速度一般是多少
SpringBoot默认情况下是给200线程(池)用于处理请求的。你现在既然CPU才50%,说明线程没有跑满CPU。controller处理时间200毫秒的话,一个线程一秒能处理5个请求,在CPU足够的情况下,200线程应该一秒能处理1000请求左右。所以按道理应该不会出现你说的状况。你这种状况看起来请求有排队现象。
那么这样的话,你可能要检查下:
1.有没有改tomcat(或者其他容器)的线程池容量。默认是200,如果改太低了,譬如降到50,一秒最多就只能处理250请求,多出来的请求排队,就会出现这种状况。
2. 有没有实现不合理的filter,filter在controller之前运行,如果实现不好,有太多等待(也就是处理慢)也可能会有这种状况