原文:http://www.mastertheboss.com/jboss-performance/jboss-as-7-performance-tuning/page-4



调优Webserver线程池

还有非常多须要调优的地方终于影响Webserver的性能。当中一个最重要的因素是调优HTTP线程池设置,以匹配web请求的负载。

这事实上是非常难做到的,但可通过调优获得最佳性能。

webserver的线程数量是通过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章。配置应用程序server,以获取有关线程子系统具体介绍):

<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-threadsmax-threads,这些值设置的太低,可能没有足够的线程来处理全部的请求,在这样的情况下,请求不被处理必须等待一段时间,直到还有一个请求线程被释放。

过低的值也意味着JBoss的Webserver将无法充分利用server硬件的优势。

还有一方面,要小心设置这些线程数,线程数设置过高会导致:

•    消耗大量的内存;

•    系统会消耗很多其它的时间做上下文切换。

你应该首先调查是否存在个别的请求耗用过长的时间。线程是否返回到池中?假设存在这样的情况,可能原因是。数据库连接没有释放,线程排队等待获取一个数据库连接,从而使其它请求无法得到处理。

在这样的情况下,简单地添加很多其它的线程会消耗很多其它CPU,GC更加频繁,从而使事情变得更糟。在应用程序中你能够通过採取简单的线程转储(thread dump),找出webserver线程到底在哪里堵塞。比如在这张图片中,从JConsole的线程选项卡中,通过观察它的堆栈跟踪。你能够看到看起来和以下类似的空暇线程idle thread):

还有一方面,以下的HTTP线程忙于做输入/输出操作。可能的原因是,比如Webserver正在从外部资源获取数据。

从上面的快照能够指导你怎样监视Webserver上执行的线程,仅仅需在最以下的文本框填写executor的名称(http-executor),就会显示全部Webserver线程的列表。

JBoss AS 7性能调优(三)的更多相关文章

  1. Java 代码性能调优“三十六”策

    代码优化,一个很重要的课题.可能有些人觉得没用,一些细小的地方有什么好修改的,改与不改对于代码的运行效率有什么影响呢?这个问题我是这么考虑的,就像大海里面的鲸鱼一样,它吃一条小虾米有用吗?没用,但是, ...

  2. Spark常规性能调优

    1.1.1     常规性能调优一:最优资源配置 Spark性能调优的第一步,就是为任务分配更多的资源,在一定范围内,增加资源的分配与性能的提升是成正比的,实现了最优的资源配置后,在此基础上再考虑进行 ...

  3. PHP 性能分析第三篇: 性能调优实战

    注意:本文是我们的 PHP 性能分析系列的第三篇,点此阅读 PHP 性能分析第一篇: XHProf & XHGui 介绍 ,或  PHP 性能分析第二篇: 深入研究 XHGui. 在本系列的 ...

  4. mysql监控、性能调优及三范式理解

    原文:mysql监控.性能调优及三范式理解 1监控 工具:sp on mysql     sp系列可监控各种数据库 2调优 2.1 DB层操作与调优 2.1.1.开启慢查询 在My.cnf文件中添加如 ...

  5. [Spark性能调优] 第三章 : Spark 2.1.0 中 Sort-Based Shuffle 产生的内幕

    本課主題 Sorted-Based Shuffle 的诞生和介绍 Shuffle 中六大令人费解的问题 Sorted-Based Shuffle 的排序和源码鉴赏 Shuffle 在运行时的内存管理 ...

  6. sql server 性能调优 资源等待之内存瓶颈的三种等待类型

    原文:sql server 性能调优 资源等待之内存瓶颈的三种等待类型 一.概述 这篇介绍Stolen内存相关的主要三种等待类型以及对应的waittype编号,CMEMTHREAD(0x00B9),S ...

  7. Jboss性能调优

    1,Jboss5调优指南 https://www.redhat.com/f/pdf/JB_JEAP5_PerformanceTuning_wp_web.pdf 1,Jboss7.1 性能调优指南 a: ...

  8. 十八般武艺玩转GaussDB(DWS)性能调优(三):好味道表定义

    摘要:表结构设计是数据库建模的一个关键环节,表定义好坏直接决定了集群的有效容量以及业务查询性能,本文从产品架构.功能实现以及业务特征的角度阐述在GaussDB(DWS)的中表定义时需要关注的一些关键因 ...

  9. web前端性能调优

    最近2个月一直在做手机端和电视端开发,开发的过程遇到过各种坑.弄到快元旦了,终于把上线了.2个月干下来满满的的辛苦,没有那么忙了自己准备把前端的性能调优总结以下,以方便以后自己再次使用到的时候得于得心 ...

随机推荐

  1. Mybatis分页插件PageHelper正确的用法(网上有2篇不够科学的文章)

    今天下午在Mybatis项目中.实现分页.由于我是后加入项目中的,Leader用的是PageHelper这个组件.可是我在实际使用的过程中遇到了2个大问题. 1.p=2#comments" ...

  2. VMware vSphere 5.5的12个更新亮点(1)

    [IT专家网虚拟化]在VMworld 2013大会上发布的VMware vSphere 5.5版本提供的增强和改进,横跨从hypervisor到管理整个堆栈,提升了VMware的性能.可伸缩性和可用性 ...

  3. [Redux] Generating Containers with connect() from React Redux (VisibleTodoList)

    Learn how to use the that comes with React Redux instead of the hand-rolled implementation from the ...

  4. android AsyncTask 详细例子(2)

    超时处理 001 import java.util.Timer; 002 import java.util.TimerTask; 003   004 import android.app.Activi ...

  5. 临时解决linux下time wait问题

     通过 netstat  -anp | grepTIME_WAIT | wc -l 命令查看数量,发现TIME_WAIT的连接数量超过了阈值   1.初步怀疑是程序没有关闭连接,codereview了 ...

  6. win7_64位主机装虚机Linux系统(VMware Workstation10+CentOS6.5)详细步骤图文讲解

    第一步:创建新的虚拟机 第二步:选择“典型”安装 第三步:选择映像文件安装—浏览选择iso文件 第四步:选择稍后安装操作系统 第五步:系统选择Linux,版本选择centOS64位 第六步:虚拟机名称 ...

  7. (转载)iOS 多媒体

    音频:(音效.音乐) 在iOS中音频播放从形式上可以分为音效播放和音乐播放.前者主要指的是一些短音频播放,通常作为点缀音频,对于这类音频不需要进行进度.循环等控制.后者指的是一些较长的音频,通常是主音 ...

  8. NPOI导入导出Excel

    .net mvc利用NPOI导入导出excel 注意:如何导出的提交方式ajax导出是失效的! 解决方案是:js处理l两个表单的提交  代码:  第一步. 在页面里面加入2个隐藏的iframe, 如下 ...

  9. C/C++中define的使用

    代码: #include <iostream> using namespace std; #define a 10 void foo(); void bar(); void foo(){ ...

  10. django 学习杂记

    django1.9 学习路径 http://python.usyiyi.cn/django/intro/tutorial02.html django 中url路径带参数,在view中应该如何处理 应该 ...