3

我在 Tomcat 7 中运行了以下简单的 JSP。容器中没有其他内容,也没有 web.xml。我在三个单独的选项卡(Chrome)中从浏览器中快速连续点击了 urlhttp://localhost:8090/test/test.jsp三次。

<%@ page import="java.util.Date" %>
<%
    out.println("Hello there dude");
    System.out.println("Hello there my friend "+ new Date() +"
                "+Thread.currentThread().getName());
    try {
        Thread.sleep(5000);
    } catch(Exception e)
    {
        e.printStackTrace();
    } 
%>

`

当我在 Tomcat 7 或任何其他版本的 Tomcat 中运行它时,JSP servlet 将阻止多个请求,并且我在控制台中得到这样的输出。

你好,我的朋友 2012 年 2 月 2 日星期四 19:31:35 MST 2012 http-bio-8090-exec-1
你好,我的朋友 2012 年 2 月 2 日星期四 19:31:40 MST 2012 年 http-bio-8090-exec-3
你好,我的朋友2012 年 2 月 2 日星期四 19:31:45 MST http-bio-8090-exec-4

如果您检查时间,您将看到 JSP servlet 正在串行执行。我同时启动了它们,所以我相信它们应该在一秒钟内完成,但是后续请求要等到前一个请求完成后才会开始。这些是上面的开始时间,浏览器将在最后一个请求上挂起 15 秒。如果我理解规范,JSP 请求应该并行执行,因为我不要求单线程行为。

有趣的是,Tomcat 分配了不同的线程,如上所示,但它们肯定是串行执行的。这就像容器不会释放一个新的 JSP servlet 线程来处理,直到正在进行的请求完成。我们整天都在运行 Web 服务,它们似乎并行执行得很好。

我在多核 Windows 机器上运行,默认开箱即用的 Tomcat 配置有 200 个可用线程。

4

1 回答 1

3

看起来这实际上是浏览器阻塞请求的情况,而不是 Tomcat 阻塞线程的情况。我刚刚在我的 Tomcat 7 安装上尝试了相同的代码,并wget localhost:8060/ThreadTest/ &快速连续运行了 3 次,所有三个都在 1 秒内完成。

于 2012-02-03T19:59:24.153 回答