如何调高COM+中STA对象线程池的大小
来源:互联网 发布:图标windows mail 编辑:程序博客网 时间:2024/05/16 09:59
微软的设计使然,STA线程模型组件在COM+中,每个CPU支持最多10个实例。
首先,这一切定义描述在
http://support.microsoft.com/default.aspx?scid=kb;EN-US;282490
中,
节选如下:
Thread Pool in COM+In COM+, each server application maintains two separate thread pools. One thread pool services STA objects, and another thread pool services free threaded components. The latter thread pool has no upper limit on the number of threads.
|
在
http://support.microsoft.com/default.aspx?scid=kb;EN-US;303071
中,指出一个注册表项可以使得COM+模拟MTS,线程池扩展到100个线程:
However, under certain scenarios, slow middle-tier servers may experience low performance due to the lack of threads and concurrency in COM+ run time. Beginning with Post Microsoft Windows 2000 Service Pack 2 COM+ Rollup Hotfix 10 (which allows COM+ to simulate MTS behavior), the following registry key can be added: HKEY_LOCAL_MACHINE/Software/Microsoft/COM3/STAThreadPool Any value other than zero for the EmulateMTSBehavior value causes the thread pool to emulate MTS behavior, that is, one activity for each thread and 100 maximum threads for each package. If you experience performance problems while CPU utilization is low, you can set this key to increase the chance of assigning a thread to your request. |
或者您可以参看:
http://www.dev-purgatory.org/COMplus_threadpool.htm
How to tune the COM+ threadpool for STA objects
MTS had one activity per STA thread and a limit of 100 STA threads by default which could be changed since NT SP4 by an entry in the registry. COM+ has now 5 activities maximum per STA thread and a fixed limit of 10*number of processors, e.g. 10 threads on a 1cpu box.
COM+ creates 7 + number of processors STA threads when the application starts. When COM+ receives a client requests, it searches the least busy thread and inserts in its queue the created activity. When all threads have 5 activities "In-call" COM+ creates a new thread for the next incoming call. So for a 1cpu box you will see more than 8 threads only when more than 40 activities are in call.
So COM+ differs much in threadpooling from MTS and you can nearly nothing do to avoid blocking activities - nearly :-)
Hm, you certainly remember that you can still configure the threadpool for an IIS-application under IIS5 - so under COM+.
Well here is the hack - not documented, not supported:
The DWORD entry MaxThreadsPerCPU in HKLM/SOFTWARE/MICROSOFT/COM3 can be used to increase the thread limit.
But there's still the problem with the 5 activities per thread and so still the blocking problem!
The value of 5 activities per thread is hardcoded in source code and can be changed only by a COM method IComSTAThreadSTAPoolKnobs.SetActivityPerThread() and this function is not documented so not public. This method is called for example by IIS5.
update:
Since MS has recognized that the new STA pool behaviour can let perform old MTS apps quite bad, MS has introduced a new registry value in with Post Microsoft Windows 2000 Service Pack 2 COM+ Rollup Hotfix 10:
HKEY_LOCAL_MACHINE/Software/Microsoft/COM3/STAThreadPool
Value name: EmulateMTSBehavior Data type: REG_DWORD Value data: default is 0
"Any value other than zero for the EmulateMTSBehavior value causes the thread pool to emulate MTS behavior, that is, one activity for each thread and 100 maximum threads for each package. If you experience performance problems while CPU utilization is low, you can set this key to increase the chance of assigning a thread to your request."
感谢Steffen Ramlow。
Zhengyun (at) tomosoft.com 收藏。
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=12729
- 如何调高COM+中STA对象线程池的大小
- 如何调高COM+中STA对象线程池的大小
- 如何调高COM+中STA对象线程池的大小
- 如何调高COM+中STA对象线程池的大小
- 如何调高COM+中STA对象线程池的大小
- 如何调高COM+中STA对象线程池的大小
- 你注意到COM编程中“STA 单线程套间”的重入问题了吗?
- COM线程模型 - STA接口
- COM线程模型 - STA接口 (MTA客户,跨线程传递COM对象)
- COM线程模型 - MTA接口 (传递MTA COM对象给STA套间线程)
- COM线程模型 - STA接口 - Part III (MTA客户,跨线程传递COM对象)
- COM线程模型 - MTA接口 - Part II - (传递MTA COM对象给STA套间线程)
- COM线程模型 - STA接口 (跨线程传递对象,消息循环)
- COM线程模型 - STA接口 - Part II -(跨线程传递对象,消息循环)
- 单线程环境中对象大小可变的内存池
- 单线程环境中对象大小固定的内存池
- COM线程模型 - MTA接口 (STA套间调用MTA对象)
- COM线程模型 - MTA接口 - Part III -(STA套间调用MTA对象)
- [SQL]启动SQLServer的死锁检查
- QC之旅途笔记
- 不翼而飞的Windows Fax Service
- [COCOON+Jfor]将FO转换为RTF格式文档(二)
- 从X400地址得到SMTP地址
- 如何调高COM+中STA对象线程池的大小
- 数据库复制
- [WiX]我的第一个WiX安装脚本
- 不翼而飞的Windows Fax Service
- 【新媒体观察】AOL、CNN、USA today、CNet等旧势力卷土重来
- [地心游记]探讨以大客户为核心的增值体系
- [PHP]不同操作系统下PHP接收POST数据问题
- 调试分布式 Web 应用程序
- 阳为SS/SN 阴为SP(中)