tomcat的三种运行模式
tomcat
Tomcat Connector的三种不同的运行模式性能相差很大,有人测试过的结果如下:
这三种模式的不同之处如下:
●BIO:
一个线程处理一个请求。缺点:并发量高时,线程数较多,浪费资源。
Tomcat7或以下,在Linux系统中默认使用这种方式。
●NIO:
利用Java的异步IO处理,可以通过少量的线程处理大量的请求。
Tomcat8在Linux系统中默认使用这种方式。
Tomcat7必须修改Connector配置来启动:
connectionTimeout="20000"redirectPort="8443"/>
●APR:
即Apache Portable Runtime,从操作系统层面解决io阻塞问题。
Tomcat7或Tomcat8在Win7或以上的系统中启动默认使用这种方式。
Linux如果安装了apr和native,Tomcat直接启动就支持apr。(安装方法:http://www.cnblogs.com/nb-blog/p/5278502.html)
官方对这三种的区别的详细说明:
JavaBlockingConnectorJavaNioBlockingConnectorAPR/nativeConnector
BIO NIO APR
ClassnameAjpProtocolAjpNioProtocolAjpAprProtocol
TomcatVersion3.xonwards7.xonwards5.5.x onwards
SupportPollingNO YES YES
PollingSizeN/A maxConnections maxConnections
ReadRequestHeadersBlockingSimBlockingBlocking
ReadRequestBodyBlockingSimBlockingBlocking
WriteResponseBlockingSimBlockingBlocking
WaitfornextRequestBlockingNonBlockingNonBlocking
MaxConnectionsmaxConnections maxConnections maxConnections
Tomcat启动的时候,可以通过log看到Connector使用的是哪一种运行模式:
StartingProtocolHandler["http-bio-8080"]
StartingProtocolHandler["http-nio-8080"]
StartingProtocolHandler["http-apr-8080"]
例如:
本文参考社区文章
网友评论