TomEE 中的 Spring Durable JMS 订阅者不允许在使用的连接上设置 clientID

问题描述

我正在将在 TomEE 7 上运行的应用程序更新到 TomEE 8,在此过程中,我们开始收到有关 Spring 消息侦听器容器的错误。 TomEE 8 运行 Apache Active MQ 5.16,其中 TomEE 7 运行 Apache Active MQ 5.15.13。

在 Spring 中,我们通过 JNDI 查找获取连接工厂,该查找在我们的 tomee.xml 中定义如下

<tomee>

  <Connector id="resources/jms/ConnectionFactory" type="javax.jms.ConnectionFactory">
      ResourceAdapter=ActiveMQResourceAdapter
      TransactionSupport xa
      PoolMaxSize 10
      PoolMinSize 0
      ConnectionMaxWaitMilliseconds 15000
      ConnectionMaxIdleMinutes 15
      MaxSessions=5
  </Connector>

  <Resource id="ActiveMQResourceAdapter" type="ActiveMQResourceAdapter">
      brokerXmlConfig=xbean:file:conf/activemq.xml
      ServerUrl=tcp://localhost:61616
  </Resource>

</tomee>

在 Spring 中我们得到如下的连接工厂

<jee:jndi-lookup id="jmsFactory" jndi-name="jms/ConnectionFactory" expected-type="javax.jms.ConnectionFactory" />

DefaultMessageListenerContainers 配置如下

<jms:listener-container container-type="default" connection-factory="jmsFactory" client-id="clientId" cache="connection" destination-type="durabletopic" transaction-manager="transactionManager">
        <jms:listener id="responses" destination="response" ref="msgHandler" />
    </jms:listener-container>

这一切都在 TomEE 7 上按预期工作,但是,现在我们已经转移到 TomEE 8,我们的 DefaultMessageListenerContainers 抛出以下异常

[org.springframework.jms.listener.DefaultMessageListenerContainer] - Could not refresh JMS Connection for destination 'response' - retrying using FixedBackOff{interval=5000,currentAttempts=9,maxAttempts=unlimited}. Cause: Setting clientID on a used Connection is not allowed

很明显,我们正在做一些与更新不正确的事情,使用 JTA 托管事务配置具有持久主题的 DMLC 的正确方法是什么?

解决方法

经过进一步测试,我发现问题与 tomee.xml 中连接工厂配置的最大池大小有关。增加这个数字我能够解决这个问题。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...