spring boot使用经验分享(一)tomcat参数配置

网上有着各种各样对spring boot原理和如何使用的讲解,我就不再多过论述了。我在这里分享下自己在使用spring boot中的经验。

一、常用参数

springboot  tomcat配置时,最多改动的配置是maxThreads、acceptCount、maxConnections

maxThreads(最大线程数):每接到一个HTTP请求,tomcat都会创建一个线程来处理该请求,最大线程数决定了Web服务最多可以同时处理多少个请求(默认200)

acceptCount(最大等待数):当HTTP请求数达到tomcat的最大线程数时,新的HTTP请求到来时,tomcat会将该请求放在等待队列中。acceptCount为能够接受的最大等待数(默认100)。如果等待队列也放满了,tomcat就会拒绝新的请求(connection refused)。

maxConnections(最大连接数):同一时间内,tomcat能够接受的最大连接数(默认10000)。当Tomcat接收的连接数达到maxConnections时,Acceptor线程不会读取accept队列中的连接,accept队列中的线程会一直阻塞着,直到Tomcat接收的连接数小于maxConnections。

二、常见误区

看到这里有人可能觉得,为了让tomcat能够同时处理更多的线程,我是不是就可以把这几个值调的尽量大就可以了?

但是要考虑到增加线程是有成本的!

首先,创建新线程时,JVM会默认分配大小为1M的线程栈,线程数的增加同时代表着占用内存的增加。

其次,线程数过多会导致大量线程上下文切换成本暴增。

最后,即使配置够大,但是也没有有可用的资源来处理暴增的请求,进入的请求等待时间会很长,影响整体的效率。

三、参数设置

maxThreads:与应用有关,同时也与服务器的CPU核心数量有关。1核2g内存建议配置为200,4核8g内存,建议配置成800,当然具体配置时最好压测下。

acceptCount:如果设置过大,请求等待时间可能会很长。但是如果设置过小,请求会立马返回connection refused。一般设置的跟maxThreads一样大,当然这个值需要根据应用的访问峰值与平均值来权衡配置下。

maxConnections:一般使用默认值

四、其他可能用到的参数

minSpareThreads:最小工作空闲线程数,默认10。(可以适当调大一点,应对突增的访问量)

发布了43 篇原创文章 · 获赞 0 · 访问量 3913

猜你喜欢

转载自blog.csdn.net/zhangdx001/article/details/104968274