我有以下消息消费者
@Service
public class BlockServiceConsumer {
public void blockService(PhoneServiceVO phoneServiceVO) throws Exception {
// message processing
}
jms:listener-container
connectionFactory
并遵循带有和queue
定义的弹簧配置
<context:component-scan base-package="com.stealthgenie.scheduler" />
<context:annotation-config/>
<bean id="blockServiceQueue" class="org.apache.activemq.command.ActiveMQQueue">
<constructor-arg value="BLOCK_SERVICE.QUEUE"/>
</bean>
<bean id="connectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
<property name="brokerURL">
<value>tcp://localhost:61616</value>
</property>
</bean>
<jms:listener-container acknowledge="auto" connection-factory="connectionFactory" destination-type="queue" concurrency="10-20">
<jms:listener destination="BLOCK_SERVICE.QUEUE" ref="blockServiceConsumer" method="blockService" />
</jms:listener-container>
我的问题:尽管文档中提到它是必需的,但为什么这个设置在没有实现的情况下可以正常工作。MessageListener
注意我也没有使用MessageListenerAdapter
以类似于 EJB 世界中的消息驱动 Bean (MDB) 的方式,消息驱动 POJO (MDP) 充当 JMS 消息的接收者。MDP 的一个限制(但也请参见下面对 MessageListenerAdapter 类的讨论)是它必须实现 javax.jms.MessageListener 接口。另请注意,如果您的 POJO 将在多个线程上接收消息,请务必确保您的实现是线程安全的。