之前项目一直在tomcat下开发,后来在上线之前,需要进行性能安全测试,可是测试的同事反应,登陆口线程并发一多的时候,系统立马就没法登陆了。
中间件是tomcat6. tomcat的日志总是简洁的很,在控制台只发现一句 超过系统最大线程的错误。系统并没有死,只是不再响应了。开始以为是线程池满了的原因
后来调整了也还是这个错误,而且jvm也很正常。后来排查到最后,发现是系统基础平台那边的一个bug,升级了相应的jar包后就好了。
升级后,在不对tomcat进行线程池优化的前提下,还是会报出超过最大线程的警告,tomcat默认的最大线程是200.
因此调整了一下。
- <Connector port="8081"
- redirectPort="18443"
- protocol="org.apache.coyote.http11.Http11Protocol"
- URIEncoding="UTF-8" minSpareThreads="25" maxSpareThreads="75"
- enableLookups="false" disableUploadTimeout="true" connectionTimeout="20000"
- acceptCount="300" maxThreads="300" maxProcessors="1000" minProcessors="5"
- useURIValidationHack="false"
- compression="on" compressionMinSize="2048"
- compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
- />
protocol="org.apache.coyote.http11.Http11Protocol" 这句指定当前的访问协议,必须要写全,在tomcat 6.0.44 下不写全,会报一个警告,警告下面的参数无法识别。
几个主要的参数:
- minSpareThreads="25" 线程池中最小的线程数
- maxSpareThreads="75" 线程池中最大的不活动线程数
- maxThreads="300" 启动的用来接收请求的线程的最大数。即最大线程响应数目。最大并发数。
- acceptCount="300" 当上面的并发数达到限值后,剩余的请求将被放置到一个队列中,该数目代表该队列的最大值,超过则拒绝对应请求。
- enableLookups="false"
- disableUploadTimeout="true"
- connectionTimeout="20000"
- maxProcessors="1000"
- minProcessors="5"
- useURIValidationHack="false"
- compression="on"
- compressionMinSize="2048"
- compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
通过上面的调整, tomcat在持续并发300的情况下,响应是很不错的。 可以通过tomcat自己的控制台,用jemeter模拟了1s1000个线程, 看到tomcat的busy 线程持续在300,证明,上面的调优后,并发300 tomcat完全没问题。