我使用的是Wildfly 14中部署的Spring-Boot-WAR,并实现了一个连接到队列的JmsListener。JmsListener将并发设置为5,当Spring-App独立启动时,我看到5个并行工作的侦听器。但是结合Wildfly 14,只有一个监听器在运行。
在JEE中,我会用@ MessageDrivenBean注释池,然后可以为给定池配置最大池大小。但是我认为Spring-Listener只是连接到默认的MDB-Pool,它的大小是1。
有没有一种方法可以将JmsListener与特定的bean-instance-pool连接起来?或者,有没有其他方法可以为这个JmsListener定义一个单独的最大池大小?
standalone.xml
<subsystem xmlns="urn:jboss:domain:ejb3:5.0">
...
<pools>
<bean-instance-pools>
...
<strict-max-pool name="individual-strict-max-pool" max-pool-size="5" instance-acquisition-timeout="5" instance-acquisition-timeout-unit="MINUTES"/>
</bean-instance-pools>
</pools>
JmsListener
@JmsListener(destination = JMS_MESSAGE_NAME, concurrency = "5")
public void receiveFromMessageQueue(Message msg) {
...
}发布于 2021-11-18 14:35:57
在JEE应用服务器中,JCA规范将JMS连接上的JMS会话数量限制为一个。在Spring Boot部署中,JmsListener上有5个并发使用者。这是通过在由Spring JMS侦听器容器管理的一个JMS连接上拥有5个JMS会话来实现的。
如果您实例化自己的连接工厂(不使用Wildfly JCA连接工厂),那么每个连接可以有多个会话。
https://stackoverflow.com/questions/70016681
复制相似问题