我在 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 个可用线程。