dan*_*nik 7 spring tomcat servlets spring-mvc servlet-3.0
我编写了非常简单的控制器,测试Servlet 3的功能:
@Autowired
ThreadPoolTaskExecutor taskExecutor;
@RequestMapping(value="{name}", method = RequestMethod.GET)
public @ResponseBody DeferredResult<MyResponse> getShopInJSON(@PathVariable String name) {
DeferredResult<MyResponse> df = new DeferredResult<MyResponse>();
taskExecutor.submit(new MyRunnable(df));
return df;
}
Run Code Online (Sandbox Code Playgroud)
在单独的线程中,我只做5秒的睡眠命令,之后我将MyResultPOJO 返回给DeferredResult.
我的web.xml文件符合Servlet 3规范:
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0"
metadata-complete="true">
<display-name>Archetype Created Web Application</display-name>
<servlet>
<async-supported>true</async-supported>
<servlet-name>mvc-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>mvc-dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
Run Code Online (Sandbox Code Playgroud)
我的连接器tomcat如下:
<Connector port="8080" protocol="HTTP/1.1"
maxThreads="5"
acceptCount="5"
connectionTimeout="20000"
redirectPort="8443" />
Run Code Online (Sandbox Code Playgroud)
现在这是有趣的部分.当运行打开10个并发连接的简单程序时,我看到第一个集合被释放后,首先只提供5个连接,然后提供第二个5个连接(您可以从时间步进中看到它).这不是Servlet 3.0应该如何表现的
Fri May 31 01:17:57 IDT 2013: Preparing 10 concurrent connections
Fri May 31 01:18:02 IDT 2013: Output from Server int thread 9 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:02 IDT 2013: Output from Server int thread 8 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:02 IDT 2013: Output from Server int thread 4 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:02 IDT 2013: Output from Server int thread 7 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:02 IDT 2013: Output from Server int thread 2 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:07 IDT 2013: Output from Server int thread 1 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:07 IDT 2013: Output from Server int thread 0 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:07 IDT 2013: Output from Server int thread 5 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:07 IDT 2013: Output from Server int thread 6 :{"props1":"param1","props2":"param1"}
Fri May 31 01:18:07 IDT 2013: Output from Server int thread 3 :{"props1":"param1","props2":"param1"}
Run Code Online (Sandbox Code Playgroud)
如果将Tomcat Connector更改为
<Connector connectionTimeout="200000" maxThreads="5" port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol" redirectPort="8443"/>
Run Code Online (Sandbox Code Playgroud)
它就像魅力一样.我不想这样做.根据Tomcat文档,我应该接收没有Http11NioProtocol连接器的Servlet 3.0功能.
怎么了?
问题是由于Tomcat配置中的maxThreads = 5设置.
对于非NIO情况,此设置不仅限制请求处理线程的最大数量,还限制最大连接数!
由于您尚未指定maxConnections,因此它正在为maxConnections选择默认值.以下是Tomcat doc关于如何选择maxConnections的默认值的摘录:
maxConnections:服务器在任何给定时间接受和处理的最大连接数.达到此数量后,在连接数低于此值之前,服务器将不再接受任何连接.操作系统仍可以接受基于acceptCount设置的连接.默认值因连接器类型而异.对于BIO,缺省值是maxThreads的值,除非使用Executor,在这种情况下,缺省值将是执行程序中maxThreads的值.对于NIO,默认值为10000.对于APR/native,默认值为8192.
您可以显式指定maxConnections ="10"(例如)设置以覆盖此默认行为.然后,您应该看到无论使用哪种连接器,都可以获得10个并行请求.我试过这个并且它有效.
| 归档时间: |
|
| 查看次数: |
6385 次 |
| 最近记录: |