首先吐槽一下这两天碰到的bug都是之前没有碰到,网上也没有解决方案的情况。神烦。
今天mq工具封装升级,突然发现报jms refresh connection failed, client already connected。从错误提示上看很容易判断是client已经链接,重复链接导致的。但是为什么呢?百度一圈,都是重启mq,把client设置为不同之类的。完全没有解决问题。那我还是分以下几个角度来说明这个问题。
一、发生背景是:springboot2 jms activemq整合,并且想同时支持queue和topi两种模式。所以配置文件不好使,只能自己自定义listener bean.并且因为queue消息重要,还要持久化和重发。
二、发生条件。抛开条件谈结果都是耍流氓。具体条件:
1、同时支持queue和topic,也就是定义两个listener factory。如果单一的模式,直接配置文件,没有问题。
2、一个activeconnectionfactory。(即使定义两个也没用)
3、activemq
4、订阅模式指定了client id
三、根本原因。
active connection factory默认是单会话client。订阅模式会刷新client,如果指定了connection factory 或listener factory client id,那旧的会话没有断开,新的去连接,client一样,就会报这样的错误。
四、解决方案。
1、将ActiveMQConnectionFactory改为JmsPoolConnectionFactory.(如果spring boot,配置pool后,自动注入即可,不需要new)
2、不要指定client id(连接池会动态指定client id,不会重复)
五、建议
在拆分功能时,尽量将多个模式的功能完全拆分,减少资源复用带来的影响,除非你能把控复用的影响性。排查问题时,也是一步步将queue topic模式用到的bean一一拆分,最后发现topic还是报错。那就说明topic配置问题。
这块目前感觉还是没有研究透彻,可能原因分析的不对。暂时写个博文供大家参考。