背景:我在我的Websphere 7应用程序中使用
Spring 3.0.x来获取CommonJ WorkManager和TimerManager.我使用它们在我部署的应用程序中以特定间隔执行任意任务.
问题:
我刚刚了解到在调度程序中设置bean时如此:
<bean id="threadTest" class="test.ThreadTester" />
<task:scheduled-tasks scheduler="myTimerExecutor">
<task:scheduled ref="threadTest" method="execute" fixed-delay="300000" />
</task:scheduled-tasks>
在Websphere中,它将直接在TimerManager线程池中运行ThreadTester类.此线程池具有比WorkManager线程池高得多的优先级(和更少的线程).我希望线程与WorkManager一起运行,而不是正确的优先级,并使用为线程设置的适当资源.
作为替代方案,我可以在ThreadTester类中使用Spring @Scheduled注释,而不是像上面那样在调度程序中设置bean:
@Scheduled(fixedDelay = 300000)
public void execute() {
...
}
题:
使用@Scheduled批注是否使计划的类在TimerManager线程池或WorkManager线程池中运行?
如果它使用WorkManager运行,那太好了!这解决了我的问题.但是,如果它使用TimerManager直接执行类,那么我想我必须编写一些包装器才能正确调用WorkManager.
谢谢你的帮助!
编辑:这里我包括如何使用Websphere 7 commonj实现设置调度程序和执行程序:
<bean id="myTaskExecutor" class="org.springframework.scheduling.commonj.WorkManagerTaskExecutor">
<property name="workManagerName" value="wm/default" />
<property name="resourceRef" value="true"/>
</bean>
<bean id="myTaskScheduler" class="org.springframework.scheduling.commonj.TimerManagerTaskScheduler">
<property name="timerManagerName" value="tm/default" />
<property name="resourceRef" value="true" />
<property name="shared" value="false" />
</bean>
<task:annotation-driven executor="myTaskExecutor" scheduler="myTaskScheduler" />
最佳答案 好吧,我发现是的,确实,@ Scheduled bean在Websphere 7上的TimerManager线程池中运行.
我所要做的只是吐出线程的堆栈跟踪,以查看调用它的层次结构.
for(StackTraceElement element: Thread.currentThread().getStackTrace()) {
logger.debug(element.toString());
}