我正在使用我的 Web 应用程序中的 Spring JmsTemplate 类向 IBM WebSphere MQ(mq jar 版本为 7.0.1.9,javax.jms 为 1.1)发送消息。
我使用的 connectionFactory 是 MQQueueConnectionFactory。
以下守护线程是在 JmsTempalte 上执行 send() 和实例化 MQQueueConnectionFactory 时创建的。
问题
当我在 tomcat 管理页面中停止 Web 应用程序时,我在 tomcat 命令行上收到一条消息,将这三个线程显示为内存泄漏。守护线程是
来自 JCONSOLE
线程 1
名称:JMSCCThreadPoolMaster 状态:在 java.lang.Object@9f6e3e9 上等待总阻塞:3 总等待:4
堆栈跟踪:java.lang.Object.wait(Native Method) 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)
线程 2
名称:JMSCCThreadPoolWorker-2 状态:WAITING on com.ibm.mq.jmqi.remote.internal.RemoteReconnectThread$ReconnectMutex@3d3c3e45 阻塞总数:0 等待总数:1
堆栈跟踪:java.lang.Object.wait(Native Method) 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)
线程 3(一分钟后死亡)
这个是在实例化 MQQueueConnectionFactory 时创建的
名称:WebSphere MQ 跟踪监视器状态:TIMED_WAITING 阻塞总数:0 等待总数:5
堆栈跟踪:java.lang.Thread.sleep(Native Method) com.ibm.mq.commonservices.internal.monitor.TraceMonitor.run(TraceMonitor.java:134)
如何确保这些守护线程死亡。