本文详解 websphere 7 中因未正确结束事务引发的 ibm mq 连接泄漏问题,重点分析 `state_active_inuse` 状态连接长期占用、线程阻塞及 `classnotfoundexception` 的深层关联,并提供可落地的代码规范、配置优化与诊断策略。
在 WebSphere Application Server(WAS)7.0.0.45 环境中集成 IBM MQ 7.0.1.14 资源适配器时,若出现连接句柄长时间处于 STATE_ACTIVE_INUSE 状态(如日志中显示 Time inuse 3629 (seconds)),且线程(如 WebContainer : 2)持续阻塞,根本原因通常并非连接未显式关闭,而是底层事务未正常提交或回滚,导致 WAS 连接管理器(ConnectionManager)无法回收物理连接。
从您提供的堆栈和关键线索可明确两点:
即使使用 finally 块关闭 Connection/Session,若事务未结束,WAS 仍不会释放底层 MQ 物理连接。务必遵循以下原则:
// ✅ 推荐:使用 Spring JmsTemplate(自动管理资源与事务)
jmsTemplate.send("QUEUE.NAME", session -> {
TextMessage msg = session.createTextMessage("Hello");
return msg;
});
// 自动 commit / rollback,连接由池安全回收
// ❌ 风险:手动管理 + 未处理事务边界
Connection conn = null;
Session sess = null;
try {
conn = cf.createQueueConnection(); // 可能加入当前事务
sess = conn.createSession(true, Session.SESSION_TRANSACTED); // XA 事务
// ... send/receive ...
} catch (Exception e) {
// 若此处抛出异常但未 rollback,事务悬停!
throw e;
} finally {
// 即使调用 close(),WAS 仍等待事务结束
if (sess != null) sess.close();
if (conn != null) conn.close();
}| 项目 | 推荐配置 | 说明 |
|---|---|---|
| JMS 连接池超时 | Connection Timeout = 5s(已配置) | 仅控制“获取新连接”的等待时间,不强制终止已分配但未释放的连接 |
| 事务超时(全局) | 在 WAS 控制台 → 服务器 → 应用程序服务器 → 事务 → 设置 Total Transaction Lifetime Timeout(建议 ≤ 120s) | 强制终止卡住的事务,触发连接回收;避免 Time inuse 达数千秒 |
| 类加载隔离 | 将 MQ 客户端 JAR(如 com.ibm.mq.allclient.jar)放入 WAS 共享库(Shared Library)并绑定到应用,而非打包进 EAR 的 lib/ |
规避 ExtClassLoader 与 CompoundClassLoader 冲突导致的 ClassNotFoundException,从根源防止事务异常中断 |
| 连接泄漏追踪 | 启用精准跟踪: com.ibm.ejs.j2c.ConnectionLeakLogic=all: com.ibm.ejs.j2c.ConnectionManager=all |
比泛用 *=info 更高效,聚焦连接生命周期事件 |
通过强化事务边界控制、修正类加载策略、启用事务超时机制,可系统性根治此类“连接标记销毁却无限等待”的顽疾,确保 MQ 连接池健康运转。