一尘不染

DefaultJmsListenerContainerFactory与DefaultMessageListenerContainer

spring-boot

使用DefaultJmsListenerContainerFactoryover有DefaultMessageListenerContainer什么优点?

  • 如果直接配置DMLC,则可以通过调用来检查状态isRunning()。我也确实可以启动和停止DMLC

  • 但是,根据新的Spring规格,如果我配置DefaultJmsListenerContainerFactory,我将无法处理DMLC,因此无法执行上述任何操作。

因此,从上述限制来看,有人可以解释为什么应该DefaultJmsListenerContainerFactory在DMLC上使用

另外,如果我使用DefaultJmsListenerContainerFactory,实现上述功能的方法是什么?


阅读 766

收藏
2020-05-30

共1个答案

一尘不染

引入工厂是为了支持为带@JmsListener注释的POJO方法创建侦听器容器。

如果不使用该机制,则可以继续直接定义DLMC。

编辑

使用时@JmsListener,容器本身不会注册为bean,但是可以使用注册bean来使用;您可以获得对该容器的引用,因此可以启动/停止等。

请参阅的javadoc
JmsListenerEndpointRegistry如何通过ID或所有单独去的容器引用。

编辑2

我不确定您在评论3中的意思;注册表包含所有容器,无论使用哪个容器工厂创建容器…

@JmsListener(id="foo", destination="foo", containerFactory="one")
public void listen1(String payload) {
    System.out.println(payload + "foo");
}

@JmsListener(id="bar", destination="bar", containerFactory="two")
public void listen2(String payload) {
    System.out.println(payload + "bar");
}

如果configureListenerContainers()用于以编程方式创建端点,则必须为它们提供容器而不是容器工厂。

2020-05-30