TomEE 中的 Spring Durable JMS 订阅者(不允许在使用的连接上设置 clientID)
Posted
技术标签:
【中文标题】TomEE 中的 Spring Durable JMS 订阅者(不允许在使用的连接上设置 clientID)【英文标题】:Spring Durable JMS Subscriber in TomEE (Setting clientID on a used Connection is not allowed) 【发布时间】:2021-02-23 22:54:45 【问题描述】:我正在将在 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 FixedBackOffinterval=5000, currentAttempts=9, maxAttempts=unlimited. Cause: Setting clientID on a used Connection is not allowed
显然我们在更新时做了一些不正确的事情,使用 JTA 托管事务配置具有持久主题的 DMLC 的正确方法是什么?
【问题讨论】:
结果与订阅是否持久无关。我设置的听众数量似乎有些问题。仍在挖掘,但还没有任何事情发生在我身上。 【参考方案1】:经过进一步测试,我发现问题与在 tomee.xml 中的连接工厂上配置的最大池大小有关。提高这个数字我能够解决这个问题。
【讨论】:
以上是关于TomEE 中的 Spring Durable JMS 订阅者(不允许在使用的连接上设置 clientID)的主要内容,如果未能解决你的问题,请参考以下文章
获取 SQLException:当使用系统属性定义资源时,Driver:org.hsqldb.jdbcDriver 为 tomee 中的 URL 返回 null
Tomcat和TomEE、TomEE和TomEE Plus有啥区别
rabbitmq中的队列transient和durable的区别