Spring JmsTemplate的守护程序线程在停止tomcat应用程序后保持活动状态

时间:2014-03-13 18:11:59

标签: java spring tomcat6 ibm-mq jmstemplate

我正在使用Web应用程序中的Spring JmsTemplate类向IBM WebSphere MQ发送消息(mq jar版本为7.0.1.9,javax.jms为1.1)。

我使用的connectionFactory是MQQueueConnectionFactory。

在JmsTempalte上执行send()并实例化MQQueueConnectionFactory时,会创建以下守护程序线程

问题

我在tomcat命令行上收到一条消息,当我在tomcat管理页面中停止Web应用程序时,这三个线程显示为内存泄漏。守护程序线程是

FROM JCONSOLE

THREAD 1

名称:JMSCCThreadPoolMaster 状态:在java.lang.Object@9f6e3e9上等待 总被阻止:3总等待:4

堆栈跟踪:  java.lang.Object.wait(Native方法) java.lang.Object.wait(Object.java:485) com.ibm.msg.client.commonservices.j2se.workqueue.WorkQueueManagerImplementation $ WorkQueueManagerThread.waitForNotification(WorkQueueManagerImplementation.java:651) com.ibm.msg.client.commonservices.j2se.workqueue.WorkQueueManagerImplementation $ WorkQueueManagerThread.waitForNotification(WorkQueueManagerImplementation.java:621) com.ibm.msg.client.commonservices.j2se.workqueue.WorkQueueManagerImplementation $ WorkQueueManagerThread.run(WorkQueueManagerImplementation.java:887)

THREAD 2

名称:JMSCCThreadPoolWorker-2 状态:等待com.ibm.mq.jmqi.remote.internal.RemoteReconnectThread$ReconnectMutex@3d3c3e45 总被阻止:0总等待:1

堆栈跟踪:  java.lang.Object.wait(Native方法) java.lang.Object.wait(Object.java:485) com.ibm.mq.jmqi.remote.internal.RemoteReconnectThread.bestHconn(RemoteReconnectThread.java:672) com.ibm.mq.jmqi.remote.internal.RemoteReconnectThread.run(RemoteReconnectThread.java:129) com.ibm.msg.client.commonservices.workqueue.WorkQueueItem.runTask(WorkQueueItem.java:209) com.ibm.msg.client.commonservices.workqueue.SimpleWorkQueueItem.runItem(SimpleWorkQueueItem.java:100) com.ibm.msg.client.commonservices.workqueue.WorkQueueItem.run(WorkQueueItem.java:224) com.ibm.msg.client.commonservices.workqueue.WorkQueueManager.runWorkQueueItem(WorkQueueManager.java:298) com.ibm.msg.client.commonservices.j2se.workqueue.WorkQueueManagerImplementation $ ThreadPoolWorker.run(WorkQueueManagerImplementation.java:1220)

THREAD 3 一分钟后死亡

THIS ONE是在MQQueueConnectionFactory实例化时创建的

名称:WebSphere MQ跟踪监视器 状态:TIMED_WAITING 总被阻止:0总等待:5

堆栈跟踪:  java.lang.Thread.sleep(Native方法) com.ibm.mq.commonservices.internal.monitor.TraceMonitor.run(TraceMonitor.java:134)

如何确保这些守护程序线程死亡。

2 个答案:

答案 0 :(得分:0)

我认为问题出在WMQ客户端罐子里,而不是春天。从应用程序中删除客户端jar并在较高的类加载器级别提供它们,例如在tomcat / lib文件夹中处理它们。这不会解决问题,但可以解决这个问题,因为所有应用程序都会共享基础,并且在应用程序重启时不会发生泄漏。

答案 1 :(得分:0)

我的Spring上下文未正确关闭,JMS Connection工厂由我的弹簧容器管理,因此导致泄漏。