首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Tomcat 7.0.32 +Spring MVC Servlet 3异步不工作

Tomcat 7.0.32 +Spring MVC Servlet 3异步不工作
EN

Stack Overflow用户
提问于 2013-05-31 06:40:59
回答 2查看 6.5K关注 0票数 7

我写了一个非常简单的控制器来测试Servlet 3的特性:

代码语言:javascript
复制
@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; 
    }

在单独的线程中,我只做了5秒的睡眠命令,然后将MyResult POJO返回给DeferredResult

我的web.xml文件符合Servlet 3规范:

代码语言:javascript
复制
<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>

我的连接器tomcat如下所示:

代码语言:javascript
复制
 <Connector port="8080" protocol="HTTP/1.1"
                maxThreads="5"
                acceptCount="5"
                connectionTimeout="20000"
                redirectPort="8443" />

现在是有趣的部分。当运行打开10个并发连接的简单程序时,我看到只有5个连接首先被服务,第二个5个连接在第一组连接被释放后被服务(你可以从时间干看到它)。这不是Servlet 3.0的行为方式

代码语言:javascript
复制
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"}

如果将Tomcat连接器更改为

代码语言:javascript
复制
   <Connector connectionTimeout="200000" maxThreads="5" port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol" redirectPort="8443"/>

它就像是一种魅力。我不想这么做。根据Tomcat文档,我应该在没有Http11NioProtocol连接器的情况下接收Servlet3.0功能。

怎么啦?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-06-01 06:47:38

这个问题是由于Tomcat配置中的maxThreads=5设置造成的。

对于非NIO情况,此设置不仅限制请求处理线程的最大数量,还限制连接的最大数量!

由于您尚未指定maxConnections,因此它将为maxConnections选择默认值。下面是Tomcat doc关于如何为maxConnections选择默认值的摘录:

maxConnections :服务器在任何给定时间将接受和处理的最大连接数。达到此数量后,服务器将不再接受任何连接,直到连接数降至此值以下。操作系统可能仍会接受基于acceptCount设置的连接。默认值因连接器类型而异。对于BIO,默认值是maxThreads的值,除非使用了执行器,在这种情况下,默认值将是来自执行器的maxThreads的值。对于NIO,的默认值为10000。对于APR/native,默认值为8192。

您可以显式指定maxConnections="10“(例如)设置来覆盖此默认行为。然后,您应该会看到,无论使用哪种连接器,都可以处理10个并行请求。我试过了,它起作用了。

票数 7
EN

Stack Overflow用户

发布于 2013-05-31 07:02:08

你有没有试过把maxThreads调到10?看起来您的Tomcat连接器最多有5个线程

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16847012

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档