我正在使用在Web逻辑环境中运行的commonJ工作管理器。
我的设置如下:
我的春季申请背景
<bean id="workManagerTaskExecutor" class="org.springframework.scheduling.commonj.WorkManagerTaskExecutor"> <property name="workManagerName" value="java:comp/env/wm/UVWorkManager" /> </bean>
WEB-INF中的我的web.xml文件
<resource-ref> <res-ref-name>wm/UVWorkManager</res-ref-name> <res-type>commonj.work.WorkManager</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> </resource-ref>
和WEB-INF中的weblogic.xml文件
<work-manager>
<name>wm/UVWorkManager</name>
<min-threads-constraint>
<name>min threads</name>
<count>30</count>
</min-threads-constraint>
<max-threads-constraint>
<name>max threads</name>
<count>200</count>
</max-threads-constraint>
<capacity>
<name>max capacity</name>
<count>20</count>
</capacity>
<work-manager-shutdown-trigger>
<max-stuck-thread-time>600</max-stuck-thread-time>
<stuck-thread-count>100</stuck-thread-count>
</work-manager-shutdown-trigger>
</work-manager>
从SOAP-UI调用服务一段时间后。我收到以下错误
commonj.work.WorkException: commonj.work.WorkRejectedException: [WorkManager:002912]OverloadManager max capacity rejected request as current length 20 exceeds max capacity of 20
我知道设置的最大值会被拒绝,但为什么不回收这些线程呢?即使我等了15分钟,我也无法提交新请求。我必须重启服务。
答案 0 :(得分:0)
容量包括受约束工作集中的所有排队或执行请求。 要验证线程的状态,请执行JVM的线程转储。
您应该设置JVM标志-Dweblogic.StuckThreadHandling = true,以便在生成theard转储时在日志文件中附加WorkManager的名称。
kill -3 JVM_PID