消息确认机制:
@Bean
@Scope("prototype")
public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {
RabbitTemplate template = new RabbitTemplate(connectionFactory);
template.setMandatory(true);
template.setMessageConverter(new Jackson2JsonMessageConverter());
return template;
}
使用该代码是因为每一个方法消息确认都不一样,这样配置可以让消息生产送达确认的时候,进行个性化的操作
线程池配置:
@Bean
public RabbitListenerContainerFactory<?> rabbitListenerContainerFactory(ConnectionFactory connectionFactory) {
SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
factory.setConnectionFactory(connectionFactory);
factory.setConcurrentConsumers(1);
factory.setMaxConcurrentConsumers(10);
factory.setMessageConverter(new Jackson2JsonMessageConverter());
factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);
return factory;
}
该配置中
factory.setConcurrentConsumers(1);为初始化连接池最小连接数(常驻链接)
factory.setMaxConcurrentConsumers(10);为最大连接池数量
factory.setMessageConverter(new Jackson2JsonMessageConverter());为序列化方式
factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);确认方式,manual为手动ack.
注意,该配置为全局配置,会导致所有的消费者全部使用该配置信息.设置过大or过小很可能都无法满足需求
例如某消费者,需要100个线程,另外一个消费者只需要一个线程慢慢消费的场景
正确配置:
@Bean
public RabbitListenerContainerFactory<?> rabbitListenerContainerFactory(ConnectionFactory connectionFactory) {
SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();
factory.setConnectionFactory(connectionFactory);
factory.setMessageConverter(new Jackson2JsonMessageConverter());
factory.setAcknowledgeMode(AcknowledgeMode.MANUAL);
return factory;
}
删除掉
factory.setConcurrentConsumers(1);
factory.setMaxConcurrentConsumers(10);
在注解RabbitListener中增加concurrency来进行配套使用.1-3为最小连接数为1 最大为3
@RabbitListener(queues = 队列名称, concurrency = "1-3")
消息确认:
channel.basicAck(msg.getMessageProperties().getDeliveryTag(), false); // 确认该条消息
channel.basicNack(msg.getMessageProperties().getDeliveryTag(), false, true); // 该条消息回弹到队列头的部分马上开始重新消费.
可以通过绑定多个交换机的形式,来对他进行达到一定次数后发送到其他的队列中进行处理.