- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 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 方法)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 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)
线程 3(一分钟后消失)
这个是在 MQQueueConnectionFactory 实例化时创建的
名称:WebSphere MQ 跟踪监视器状态:TIMED_WAITING被阻止总数:0 等待总数:5
堆栈跟踪: java.lang.Thread.sleep( native 方法)com.ibm.mq.commonservices.internal.monitor.TraceMonitor.run(TraceMonitor.java:134)
如何确保这些守护线程终止。
最佳答案
我相信问题出在 WMQ 客户端 jar 中,而不是在 spring 中。从应用程序中删除客户端 jar 并在更高的类加载器级别提供它们,例如将它们复制到 tomcat/lib 文件夹中。这不会解决问题,但可以解决它,因为所有应用程序将共享公共(public)基础,并且应用程序重新启动时不会发生泄漏。
关于java - Spring JmsTemplate 的守护线程在停止 tomcat 应用程序后仍保持 Activity 状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22387349/
我是一名优秀的程序员,十分优秀!