1、目标
为了确保服务不会被过多的http长连接压垮,我们需要对tomcat设定个最大连接数,超过这个连接数的请求会拒绝,让其负载到其它机器。达到保护自己的同时起到连接数负载均衡的作用
2、
接受一个请求,此时tomcat起动的线程数已经到达maxThreads,等待队列中的请求个数也达到了acceptCount,此时tomcat会直接拒绝此次请求,返回connection refused
max-connections=max-threads+accept-count
#tomcat配置
#最大并发量
server.tomcat.max-threads=300
#接受和处理的最大连接数
server.tomcat.max-connections=600
#初始化时创建的线程数
server.tomcat.min-spare-threads=100
#可以放到处理队列中的请求数
server.tomcat.accept-count=300
3、总结
tomcat能支持最大连接数由maxConnections加上acceptCount来决定。同时maxThreads如何设定?
以下部分结论引用自:http://duanfei.iteye.com/blog/1894387
一般的服务器操作都包括两方面:1计算(主要消耗cpu),2等待(io、数据库等)
第一种极端情况,如果我们的操作是纯粹的计算,那么系统响应时间的主要限制就是cpu的运算能力,此时maxThreads应该尽量设的小,降低同一时间内争抢cpu的线程个数,可以提高计算效率,提高系统的整体处理能力。</