首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Wildfly Appserver中的Spring JMS

Wildfly Appserver中的Spring JMS
EN

Stack Overflow用户
提问于 2021-11-18 08:28:26
回答 1查看 36关注 0票数 0

我使用的是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

代码语言:javascript
运行
复制
<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

代码语言:javascript
运行
复制
    @JmsListener(destination = JMS_MESSAGE_NAME, concurrency = "5")
    public void receiveFromMessageQueue(Message msg) {
      ...
    }
EN

回答 1

Stack Overflow用户

发布于 2021-11-18 14:35:57

在JEE应用服务器中,JCA规范将JMS连接上的JMS会话数量限制为一个。在Spring Boot部署中,JmsListener上有5个并发使用者。这是通过在由Spring JMS侦听器容器管理的一个JMS连接上拥有5个JMS会话来实现的。

如果您实例化自己的连接工厂(不使用Wildfly JCA连接工厂),那么每个连接可以有多个会话。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70016681

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档