原文: http://www.mastertheboss.com/jboss-performance/jboss-as-7-performance-tuning/page-4
调优Web服务器线程池
还有很多需要调优的地方最终影响Web服务器的性能,其中一个最重要的因素是调优HTTP线程池设置,以匹配web请求的负载。这其实是很难做到的,但可通过调优获得最佳性能。
web服务器的线程数量是通过executor的属性来设置的:
<subsystem xmlns="urn:jboss:domain:web:1.0">
<connector enable-lookups="false" enabled="true" executor="http-executor" max-connections="200" max-post-size="2048" max-save-post-size="4096" name="http" protocol="HTTP/1.1" proxy-name="proxy" proxy-port="8081" redirect-port="8443" scheme="http" secure="false" socket-binding="http" /> . . . </subsystem> |
然后,在线程子系统中,可以定义将要使用的池的线程数,连同其他线程属性(参见第2章,配置应用程序服务器,以获取有关线程子系统详细介绍):
<subsystem xmlns="urn:jboss:domain:threads:1.0"> <bounded-queue-thread-pool name="http-executor" blocking="true"> <core-threads count="10" per-cpu="20" /> <queue-length count="10" per-cpu="20" /> <max-threads count="10" per-cpu="20" /> <keepalive-time time="10" unit="seconds" /> </bounded-queue-thread-pool> </subsystem> |
最重要的连接器的属性是 core-threads和 max-threads,这些值设置的太低,可能没有足够的线程来处理所有的请求,在这种情况下,请求不被处理必须等待一段时间,直到另一个请求线程被释放。过低的值也意味着JBoss的Web服务器将无法充分利用服务器硬件的优势。
另一方面,要小心设置这些线程数,线程数设置过高会导致:
• 消耗大量的内存;
• 系统会消耗更多的时间做上下文切换。
你应该首先调查是否存在个别的请求耗用过长的时间,线程是否返回到池中?如果存在这种情况,可能原因是,数据库连接没有释放,线程排队等待获取一个数据库连接,从而使其他请求无法得到处理。
在这种情况下,简单地增加更多的线程会消耗更多CPU,GC更加频繁,从而使事情变得更糟。在应用程序中你可以通过采取简单的线程转储(thread dump),找出web服务器线程究竟在哪里阻塞,例如在这张图片中,从 JConsole的线程选项卡中,通过观察它的堆栈跟踪,你可以看到看起来和下面类似的 空闲线程( idle thread):
另一方面,下面的HTTP线程忙于做输入/输出操作,可能的原因是,例如Web服务器正在从外部资源获取数据。
从上面的快照可以指导你如何监视Web服务器上运行的线程,只需在最下面的文本框填写executor的名称(http-executor),就会显示所有Web服务器线程的列表。