原文: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. C++——try、throw、catch实例学习程序

    #include<iostream> #include<stdexcept> //exception/stdexcept/new/type_info头文件里都有定义的标准异常类 ...

  2. [Regular Expressions] Introduction

    var str = "Is this This?"; //var regex = new RegExp("is", "gi"); var r ...

  3. RMAN常用备份恢复命令汇总

    RMAN命令 1.独立命令  RMAN>shutdown immediate  RMAN>startup  RMAN>backup format 'd:\backup\%d_%s.b ...

  4. Opensuse13.2开启ssh

    要开启ssh很简单,步骤分为三步 步骤1: 安装ssh zypper install ssh 步骤2:启动ssh daemon网上很多通过 service 命令或者 init.d 目录中的脚本启动ss ...

  5. Apache配置多个监听端口和不同的网站目录的简单方法(转)

    转自http://www.waaqi.com/archives/707.html 由于开发的多项目,每个项目又要独立,要用根目录地址. 所以这时候我们需要配置多个不同目录的Apache,如果是外部网可 ...

  6. php 与 jquery中$.post()与attr()方法的简单实例 amaze modal 模态窗口

    $(selector).attr(attribute,value)$.post() 在jqery中有这样一个方法,$.post()下面就这个方法做一个简单的实例: jQuery.post( url, ...

  7. 安装apache服务器时遇到只能本地访问,局域网内其他电脑不能访问apache:

    安装apache服务器时遇到只能本地访问,局域网内其他电脑不能访问apache:1.查看selinux运行状态及关闭selinux/usr/sbin/sestatus -v文本模式关闭selinux: ...

  8. TypeScript开发Vue

    用TypeScript开发Vue——如何通过vue实例化对象访问实际ViewModel对象 目录 背景 解决方案 关于Vue中的计算属性类型 TypeScript的强制类型声明语法 强制类型声明的局限 ...

  9. adb调试实用命令

    获取设备IMEI: adb shell dumpsys iphonesubinfo 文件在设备和PC端的操作:adb push [PC端源文件路径] [设备的目的文件路径] 例如:adb push C ...

  10. block(三)揭开神秘面纱(上)

    block到底是什么 我们使用clang的rewrite-objc命令来获取转码后的代码. 1.block的底层实现 我们来看看最简单的一个block: [caption id="attac ...