`
zhuyuanxiang
  • 浏览: 131351 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

Apusic AS V5.1线程池配置和调优

阅读更多

“没有最优,只有平衡”。因此在配置与调优之前,我总喜欢先介绍理论基础。
Apusic AS V5.1的线程池只是个池服务,池中没有具体的线程,池中管理的线程是与业务相关的服务启动后并加入的。线程池只负责管理池中线程的数量和生命周期,从而简化了Apusic应用服务器的池管理框架。验证线程池的方法有以下几种:
1. 在Windows下启动Apusic V5.1的mydomain域,里面不带任何自启动线程的应用,在命令行窗口下按Ctrl+Break结果见附一(各人机器可能有所不同),发现系统没有任何与线程池相关的线程启动。打开IE访问一个HTML页面,再Ctrl+Break结果见附二,发现多了两个线程:Running HTTPHandler-1(HTTP服务线程)和Idle MuxHandler-1(多路复用服务线程),Mux空闲是因为多路复用的分配工作已经完成,而HTTP忙是因为HTTP服务刚结束,KeepAlive仍然保持着。可见线程池启动时是空的,当有服务时才生成线程加入到池中,池主要负责线程的数量和生命周期。这样的设定可以避免受到攻击时无限制地创建线程而导致系统宕机;或者合理使用机器的性能,平衡分配不同线程池中的线程数量。

2. 在apusic.conf文件中自定义一个线程池Test,然后可以在自己的代码中使用Apusic AS提供的池管理技术,当然如果没有使用这个池系统也仍然可以正常运行,因为这只是个池服务,只是没有线程加入到池中而已。
<SERVICE
    CLASS="com.apusic.util.ThreadPoolService"
    NAME="Apusic:service=ThreadPool,name=Test"
    >
    <ATTRIBUTE NAME="MaxThreads" VALUE="150"/>
    <ATTRIBUTE NAME="Priority" VALUE="5"/>
    <ATTRIBUTE NAME="ServicePriority" VALUE="H"/>
    <ATTRIBUTE NAME="IdleTimeout" VALUE="300"/>
    <ATTRIBUTE NAME="MaxSpareThreads" VALUE="30"/>
    <ATTRIBUTE NAME="MinSpareThreads" VALUE="5"/>
    <ATTRIBUTE NAME="MaxQueueSize" VALUE="500"/>
</SERVICE>

3. 只提供default池,其他池都注释掉,系统依然能够正常运行,也是因为池与服务之间不是紧耦合,没有的相关的池,所有的线程统一使用default池,如果有自己的池就通过自定义池处理。
注意:如果有了自定义池,池中线程数达到最大值后,系统不会使用defalut池来处理的,从而充分保证相应服务池的控制。
例如:定义了HTTPHandler池,当HTTPHandler线程达到最大值后,其他只能在Queue中排队,如果Queue也满了,则其他请求将会被拒绝。

Apusic AS自己使用了五种池:
default:Apusic AS系统默认的线程池
MuxHandler:多路复用的线程池,主要是将请求向不同的服务,如:HTTP、JMS、ORB等服务上分配
HTTPHandler:HTTP服务的线程池
JMSHandler:JMS服务的线程池
ORBHandler:ORB服务的线程池
了解了线程池的基本概念,就可以知道在线程池配置中default池最为重要,其他池可以根据需要增加或者注释,所有线程池的配置参数都是相同的,具体的配置参数解释如下:
MaxThreads:线程池中能够运行的最大线程数,也就是提供服务的线程数,-1代表无限制
MinSpareThreads,MaxSpareThreads:线程池中最小/最大空闲的线程数,当线程数符合这个区间时无论空闲多久都不会被销毁
IdelTimeout:空闲线程超时的时间,超时后会如果运行的线程总数大于MaxSpareThreads则被销毁
Priority(1~10):受Java线程优先级管理
ServicePriority:服务启动的优先级,五种(H > A > N > B > L)
MaxQueueSize:当所有线程都忙时,为无法获得线程的请求提供队列进行排队,Size代表队列长度,队列满时请求被抛弃

Apusic AS的线程池优化:
● 一般的WEB应用部署在Apusic上时,不会用到JMS和ORB服务,因此可以将这两个池注释掉,减少资源消耗。
● 如果应用现阶段使用人数不多,但是伴随着发展应用人数会不断增长,可以将MinSpareThreads调整为符合现阶段情况的值,将MaxSpareThreads调整为符合将来的值,这样系统无须再变动就可以有效支持很长一段时间;
● 如果应用一段时间内访问量变化不大,但是系统偶尔会遇到高峰访问,那么可以设置MinSpareThreads=MaxSpareThreads;
● MaxThreads的值依据CPU数量来定,参考值50×CPU核数,具体值还需要根据应用执行过程中对CPU的压力决定。
● 关于Apusic AS V5.1服务的配置,下篇文章会单独介绍。


附一、
Full thread dump Java HotSpot(TM) Client VM (1.5.0_14-b03 mixed mode, sharing):

"AutoDeployer" prio=6 tid=0x030f2970 nid=0x9e0 in Object.wait() [0x03cef000..0x03cefc6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x23460458> (a com.apusic.deploy.runtime.AutoDeployer)
        at com.apusic.deploy.runtime.AutoDeployer.run(Unknown Source)
        - locked <0x23460458> (a com.apusic.deploy.runtime.AutoDeployer)
        at java.lang.Thread.run(Thread.java:595)

"Thread-4" prio=6 tid=0x031ca7f0 nid=0x21c in Object.wait() [0x0349f000..0x0349fd6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x2321c188> (a com.sun.corba.se.impl.javax.rmi.CORBA.KeepAlive)
        at java.lang.Object.wait(Object.java:474)
        at com.sun.corba.se.impl.javax.rmi.CORBA.KeepAlive.run(Util.java:736)
        - locked <0x2321c188> (a com.sun.corba.se.impl.javax.rmi.CORBA.KeepAlive)

"HTTPSessionSwapper" prio=6 tid=0x031d8168 nid=0xb98 in Object.wait() [0x0345f000..0x0345fa6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x2318ba58> (a java.lang.Object)
        at com.apusic.web.session.SessionManager$HouseKeeper.run(Unknown Source)
        - locked <0x2318ba58> (a java.lang.Object)

"HttpLogger" prio=2 tid=0x031be630 nid=0xfe8 in Object.wait() [0x0341f000..0x0341f9ec]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x2317d2b8> (a com.apusic.web.http.HttpLogger)
        at java.lang.Object.wait(Object.java:474)
        at com.apusic.web.http.HttpLogger.getNextRecord(Unknown Source)
        - locked <0x2317d2b8> (a com.apusic.web.http.HttpLogger)
        at com.apusic.web.http.HttpLogger.run(Unknown Source)

"MuxListener" prio=6 tid=0x031a8be8 nid=0x7dc runnable [0x033df000..0x033dfaec]
        at java.net.PlainSocketImpl.socketAccept(Native Method)
        at java.net.PlainSocketImpl.accept(PlainSocketImpl.java:384)
        - locked <0x23177890> (a java.net.SocksSocketImpl)
        at java.net.ServerSocket.implAccept(ServerSocket.java:450)
        at java.net.ServerSocket.accept(ServerSocket.java:421)
        at com.apusic.net.BlockingListenerThread.run(Unknown Source)

"Timer-0" prio=6 tid=0x031c3b08 nid=0xc98 in Object.wait() [0x0339f000..0x0339fb6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x23133120> (a java.util.TaskQueue)
        at java.util.TimerThread.mainLoop(Timer.java:509)
        - locked <0x23133120> (a java.util.TaskQueue)
        at java.util.TimerThread.run(Timer.java:462)

"LogManager" prio=2 tid=0x02e2c680 nid=0xb20 waiting on condition [0x0335f000..0x0335fbec]
        at sun.misc.Unsafe.park(Native Method)
        at java.util.concurrent.locks.LockSupport.park(LockSupport.java:118)
        at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:
841)
        at com.apusic.util.concurrent.LinkedBlockingQueue.take(Unknown Source)
        at com.apusic.logging.manager.ServerLogManager$PushThread.dequeue(Unknown Source)
        at com.apusic.logging.manager.ServerLogManager$PushThread.run(Unknown Source)

"Low Memory Detector" daemon prio=6 tid=0x00a83bf0 nid=0xa6c runnable [0x00000000..0x00000000]

"CompilerThread0" daemon prio=10 tid=0x00a537b8 nid=0xdc4 waiting on condition [0x00000000..0x02c2f6cc]

"Signal Dispatcher" daemon prio=10 tid=0x00a95a58 nid=0xeb0 waiting on condition [0x00000000..0x00000000]

"Finalizer" daemon prio=8 tid=0x00a50870 nid=0xbd0 in Object.wait() [0x02baf000..0x02bafa6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x230d25c8> (a java.lang.ref.ReferenceQueue$Lock)
        at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:120)
        - locked <0x230d25c8> (a java.lang.ref.ReferenceQueue$Lock)
        at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:136)
        at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:159)

"Reference Handler" daemon prio=10 tid=0x00a4f3e8 nid=0xf94 in Object.wait() [0x02b6f000..0x02b6faec]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x230d2650> (a java.lang.ref.Reference$Lock)
        at java.lang.Object.wait(Object.java:474)
        at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:116)
        - locked <0x230d2650> (a java.lang.ref.Reference$Lock)

"main" prio=6 tid=0x00038c00 nid=0x718 in Object.wait() [0x0007f000..0x0007fc3c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x230e0ed8> (a com.apusic.server.J2EEServer)
        at java.lang.Object.wait(Object.java:474)
        at com.apusic.server.J2EEServer.startup(Unknown Source)
        - locked <0x230e0ed8> (a com.apusic.server.J2EEServer)
        at com.apusic.server.Main.main(Unknown Source)

"VM Thread" prio=10 tid=0x00a80190 nid=0x490 runnable

"VM Periodic Task Thread" prio=10 tid=0x00a8e780 nid=0xcec waiting on condition

附二、
Full thread dump Java HotSpot(TM) Client VM (1.5.0_14-b03 mixed mode, sharing):

"Running HTTPHandler-1" prio=6 tid=0x02febe58 nid=0xbd8 runnable [0x03d6f000..0x03d6fb6c]
        at java.net.SocketInputStream.socketRead0(Native Method)
        at java.net.SocketInputStream.read(SocketInputStream.java:129)
        at java.io.BufferedInputStream.fill(BufferedInputStream.java:218)
        at java.io.BufferedInputStream.read1(BufferedInputStream.java:256)
        at java.io.BufferedInputStream.read(BufferedInputStream.java:313)
        - locked <0x234dd378> (a java.io.BufferedInputStream)
        at com.apusic.web.http.tcp.TCP_BIOProtocol.readLine(Unknown Source)
        at com.apusic.web.http.tcp.TCP_BIOProtocol.readRequestLine(Unknown Source)
        at com.apusic.web.http.tcp.TCP_BIOProtocol.read(Unknown Source)
        at com.apusic.web.http.tcp.TCP_BIOConnection.getNextRequest(Unknown Source)
        at com.apusic.web.http.ConnectionHandler.processConnection(Unknown Source)
        at com.apusic.web.http.ConnectionHandler.run(Unknown Source)
        at com.apusic.util.ThreadPoolImpl$WorkerThread.run(Unknown Source)

"Idle MuxHandler-1" prio=6 tid=0x02cc0d90 nid=0x54c in Object.wait() [0x03d2f000..0x03d2fbec]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x23147df0> (a java.lang.Object)
        at com.apusic.util.ThreadPoolImpl.getWork(Unknown Source)
        - locked <0x23147df0> (a java.lang.Object)
        at com.apusic.util.ThreadPoolImpl$WorkerThread.run(Unknown Source)

"AutoDeployer" prio=6 tid=0x03146980 nid=0x7bc in Object.wait() [0x03cef000..0x03cefc6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x2344f8c0> (a com.apusic.deploy.runtime.AutoDeployer)
        at com.apusic.deploy.runtime.AutoDeployer.run(Unknown Source)
        - locked <0x2344f8c0> (a com.apusic.deploy.runtime.AutoDeployer)
        at java.lang.Thread.run(Thread.java:595)

"Thread-4" prio=6 tid=0x031e3868 nid=0xdc8 in Object.wait() [0x0349f000..0x0349fd6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x2321c188> (a com.sun.corba.se.impl.javax.rmi.CORBA.KeepAlive)
        at java.lang.Object.wait(Object.java:474)
        at com.sun.corba.se.impl.javax.rmi.CORBA.KeepAlive.run(Util.java:736)
        - locked <0x2321c188> (a com.sun.corba.se.impl.javax.rmi.CORBA.KeepAlive)

"HTTPSessionSwapper" prio=6 tid=0x031c1948 nid=0x9f4 in Object.wait() [0x0345f000..0x0345fa6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x2318ba58> (a java.lang.Object)
        at com.apusic.web.session.SessionManager$HouseKeeper.run(Unknown Source)
        - locked <0x2318ba58> (a java.lang.Object)

"HttpLogger" prio=2 tid=0x031b8830 nid=0xb2c in Object.wait() [0x0341f000..0x0341f9ec]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x2317d2b8> (a com.apusic.web.http.HttpLogger)
        at java.lang.Object.wait(Object.java:474)
        at com.apusic.web.http.HttpLogger.getNextRecord(Unknown Source)
        - locked <0x2317d2b8> (a com.apusic.web.http.HttpLogger)
        at com.apusic.web.http.HttpLogger.run(Unknown Source)

"MuxListener" prio=6 tid=0x02e654a8 nid=0xa28 runnable [0x033df000..0x033dfaec]
        at java.net.PlainSocketImpl.socketAccept(Native Method)
        at java.net.PlainSocketImpl.accept(PlainSocketImpl.java:384)
        - locked <0x23177890> (a java.net.SocksSocketImpl)
        at java.net.ServerSocket.implAccept(ServerSocket.java:450)
        at java.net.ServerSocket.accept(ServerSocket.java:421)
        at com.apusic.net.BlockingListenerThread.run(Unknown Source)

"Timer-0" prio=6 tid=0x02e65c08 nid=0xdf0 in Object.wait() [0x0339f000..0x0339fb6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x23133120> (a java.util.TaskQueue)
        at java.util.TimerThread.mainLoop(Timer.java:509)
        - locked <0x23133120> (a java.util.TaskQueue)
        at java.util.TimerThread.run(Timer.java:462)

"LogManager" prio=2 tid=0x02e2d488 nid=0xbfc waiting on condition [0x0335f000..0x0335fbec]
        at sun.misc.Unsafe.park(Native Method)
        at java.util.concurrent.locks.LockSupport.park(LockSupport.java:118)
        at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:1
841)
        at com.apusic.util.concurrent.LinkedBlockingQueue.take(Unknown Source)
        at com.apusic.logging.manager.ServerLogManager$PushThread.dequeue(Unknown Source)
        at com.apusic.logging.manager.ServerLogManager$PushThread.run(Unknown Source)

"Low Memory Detector" daemon prio=6 tid=0x00a83c78 nid=0xc5c runnable [0x00000000..0x00000000]

"CompilerThread0" daemon prio=10 tid=0x00a53910 nid=0x780 waiting on condition [0x00000000..0x02c2f6cc]

"Signal Dispatcher" daemon prio=10 tid=0x00a95ae8 nid=0xc8c waiting on condition [0x00000000..0x00000000]

"Finalizer" daemon prio=8 tid=0x00a50870 nid=0xd10 in Object.wait() [0x02baf000..0x02bafa6c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x230d25c8> (a java.lang.ref.ReferenceQueue$Lock)
        at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:120)
        - locked <0x230d25c8> (a java.lang.ref.ReferenceQueue$Lock)
        at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:136)
        at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:159)

"Reference Handler" daemon prio=10 tid=0x00a4f3e8 nid=0x1d0 in Object.wait() [0x02b6f000..0x02b6faec]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x230d2650> (a java.lang.ref.Reference$Lock)
        at java.lang.Object.wait(Object.java:474)
        at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:116)
        - locked <0x230d2650> (a java.lang.ref.Reference$Lock)

"main" prio=6 tid=0x00038c00 nid=0x7fc in Object.wait() [0x0007f000..0x0007fc3c]
        at java.lang.Object.wait(Native Method)
        - waiting on <0x230e0ed8> (a com.apusic.server.J2EEServer)
        at java.lang.Object.wait(Object.java:474)
        at com.apusic.server.J2EEServer.startup(Unknown Source)
        - locked <0x230e0ed8> (a com.apusic.server.J2EEServer)
        at com.apusic.server.Main.main(Unknown Source)

"VM Thread" prio=10 tid=0x00a80190 nid=0xab4 runnable

"VM Periodic Task Thread" prio=10 tid=0x00a8e808 nid=0x684 waiting on condition

参考:
http://infocenter.apusic.com/help/index.jsp?topic=/com.apusic.studio.doc.server/output/eclipse/threadpool.html

1
0
分享到:
评论
1 楼 swanky_yao 2010-07-23  
问兄台两个问题:
① 配置NIO和BIO的时候,配置有多大区别?(主要是HTTPHander)
②vm.options中有一个参数配置为javax.persistence.spi.PersistenceProvider=org.hibernate.ejb.HibernatePersistence是不是就可以将JPA的实现改为Hibernate的实现?我测试过,不行(当然我也已经把Hibernate的JPA实现包拷过去了)。
谢谢

相关推荐

    Apusic应用服务器5.1文档

    金蝶Apusic应用服务器的详细文档,包括安装、管理、开发等内容。

    Apusic5.1域配置

    【Apusic5.1域配置】是针对Apusic5.1服务器的一项关键操作,它涉及到服务器的管理和应用部署。Apusic(全称Apsara Music)是阿里巴巴集团研发的企业级中间件,主要用于构建高可用、高性能的企业级服务系统。本指南将...

    Apusic AS的Web应用中调用commons-logging的流程

    在Apusic AS中,这个特性使得系统能够根据配置文件灵活地选择日志实现,例如在生产环境使用性能优秀的Log4j,在开发环境中使用简单的JUL。 调用commons-logging的流程如下: 1. **引入依赖**:在Apusic AS的项目中...

    金蝶Apusic应用服务器 V10企业版 用户手册+技术白皮书+调优手册

    AAS-V10用户手册详细介绍了如何安装、配置和管理金蝶Apusic应用服务器V10。这包括但不限于以下几个方面: 1. **安装部署**:手册将引导用户进行系统需求检查、软件下载、安装过程及启动服务器等步骤,确保顺利建立...

    AAS-V9.0用户手册.pdf

    产品安装部分包括系统配置要求和详细的安装步骤,提供了在Windows、Unix/Linux环境下以及通过压缩包方式安装Apusic应用服务器、Node Manager、Apusic HTTP Server和AAS-APM的具体方法。 ### 金蝶中间件平台 金蝶...

    Apusic SQLServer的调优记录

    总之,Apusic SQLServer的调优是一个综合性的过程,涉及到操作系统、JVM、应用服务器和数据库等多个层面。通过精细化调整这些组件的配置,可以显著提高系统的并发处理能力,降低资源消耗,从而应对高并发和潜在的...

    AAS-V10.0用户手册.pdf

    Apusic V10.0版本是对该应用服务器的一个重要更新,它包含了对系统管理、集群配置、安全性和性能等方面的增强。 在用户手册中,快速开始指南部分为新用户提供了从基本介绍到安装、使用以及删除Apusic应用服务器的...

    AAS-V10.zip

    标题"AAS-V10.zip"和描述中的"apusic"关键词指向了Apusic应用服务器,这是一款由中国万网(现阿里云)开发的企业级Java应用服务器,它为各种企业应用程序提供了一个运行平台。Apusic应用服务器遵循Java EE(以前称为...

    管理Apusic Web服务器

    Apusic Web 服务器是 Apusic 应用服务器中内置的一个高效、安全、可靠的 Web 服务器,提供完整的 Web 服务器的功能,使 Apusic 应用服务器在提供对静态页面和图形的同时,提供对 JSP、Servlet 的高效服务。Apusic ...

    ApusicServer v8.0的2014年开发版License

    【ApusicServer v8.0开发版License】是针对Apusic应用服务器的一个关键组件,它在2014年发布,主要用于授权和管理该版本的软件使用。Apusic Server是一款国内知名的企业级Java应用服务器,它支持Java EE标准,为企业...

    apache2.2+apusic6.0负载配置指南(中望)

    Apache2.2+Apusic6.0负载配置指南主要涉及两个...以上就是Apache2.2和Apusic6.0联合配置实现负载均衡的关键步骤和相关知识点,通过这样的配置,可以构建一个高效、可靠的Web服务环境,确保在高并发访问时能够稳定运行。

    金蝶Apusic V10 应用服务器用户管理手册

    总的来说,金蝶Apusic V10应用服务器用户管理手册详细介绍了产品的安装、配置、使用和管理,是用户快速掌握该产品并成功部署企业级应用的宝贵资源。无论是新手还是经验丰富的管理员,都能从中受益,提升工作效率,...

    APUSIC应用服务器配置管理.ppt

    【Apusic应用服务器配置...总结起来,Apusic应用服务器配置管理涉及到服务器域的组织、应用的部署与配置、系统资源的管理等多个层面,管理员可以根据具体需求灵活调整各项设置,确保应用服务器的稳定运行和高效性能。

    AAS-V9.0用户手册.docx

    AAS-V9.0用户手册是金蝶天燕云计算股份有限公司发布的一份详细的用户手册,旨在帮助用户了解AAS V9.0应用服务器的功能、技术架构、安装、配置、使用和维护等方面的知识。 概述 AAS V9.0是金蝶天燕云计算股份有限...

    AAS-V9.0.zip

    包含AAS-V9.0下载及试用说明

    Apusic+Apache集群配置.pdf

    总结来说,Apache+Apusic 集群配置涉及Apache的安装、负载均衡策略设定、Apusic 的集群配置、会话复制和转发以及性能调优等多个环节。通过这样的配置,可以实现高可用、高性能的服务架构,确保在高并发场景下系统的...

    Apusic--license

    金蝶中间件(Apusic)--license

    Apusic+Apache集群配置[文].pdf

    - **Apusic调优**:Apusic的配置调整可以通过`SERVICE`元素进行,例如调整服务器的内存分配、限制并发连接数等,以优化服务性能。 通过这样的配置,Apache和Apusic集群可以提供高可用性、负载均衡的服务,同时通过...

Global site tag (gtag.js) - Google Analytics