简单消息监听内容
这个类非常的强大,我们可以对它就行很多设置,对于消费者的配置项,这个类都可以满足。
1.设置事务特性、事务管理器、事务属性、事务容量(并发)、是否开启事务、回滚消息等。
2.设置消费者数量、最小最大数量、批量消费。
3.设置消息确认和自动确认模式、是否回归队列、异常捕获handler函数。
4.设置消费者标签生成策略、是否独占模式、消费者属性等。
5.设置具体的监听器、消息转换器等等。
注意:SimpleMessageListenerContainer可以进行动态设置,比如在运行中的应用可以动态的修改其消费者数量的大小、接受消息的模式等。
很多基于RabbitMQ的自制定制化后端管控台在进行动态设置的时候,也是根据这一特性去实现的。可以看出SpringAMQP非常的强大。
测试SimpleMessageListenerContainer demo,在RabbitMQConfig中添加如下代码
@Bean
public SimpleMessageListenerContainer messageContainer(ConnectionFactory connectionFactory) {
SimpleMessageListenerContainer container = new SimpleMessageListenerContainer(connectionFactory);
//设置监听队列
container.setQueues(queue001(), queue002(), queue003(), queue_image(), queue_pdf());
container.setConcurrentConsumers(1);
container.setMaxConcurrentConsumers(5);
//是否有重复队列
container.setDefaultRequeueRejected(false);
//设置签收模式
container.setAcknowledgeMode(AcknowledgeMode.AUTO);
container.setExposeListenerChannel(true);
//设置消费者标签
container.setConsumerTagStrategy(new ConsumerTagStrategy() {
@Override
public String createConsumerTag(String queue) {
return queue + "_" + UUID.randomUUID().toString();
}
});
//设置默认消息监听
container.setMessageListener(new ChannelAwareMessageListener() {
@Override
public void onMessage(Message message, Channel channel) throws Exception {
String msg = new String(message.getBody());
System.err.println("----------消费者: " + msg);
}
});
return container;
}
启动项目
观察控制台
1个连接,5个消费者,和代码定义一样
观察Channel信息
5个消费与代码定义一致
测试消息消费
启动之前的testSendMessage2()发送几条消息
观察控制台消费了发送的三条消息