我正在收听2个RabbitMQ队列。对于1个队列,我需要一个消费者来确保一次只处理一个消息。 第二个队列可以在一秒钟内接收大量消息,我需要能够一次消耗许多消息。
我有以下代码,它确实可以正常工作。但我想知道是否有更好的方法来做到这一点。
@Bean
SimpleMessageListenerContainer container(ConnectionFactory connectionFactory,
MessageListenerAdapter listenerAdapter) {
SimpleMessageListenerContainer container = new SimpleMessageListenerContainer();
container.setConnectionFactory(connectionFactory);
container.setMessageConverter(Jackson2JsonMessageConverter());
container.setQueueNames(QUEUE1);
container.setMessageListener(listenerAdapter);
container.setAdviceChain(new Advice[]{interceptor()});
return container;
}
@Bean
SimpleMessageListenerContainer container1(ConnectionFactory connectionFactory,
MessageListenerAdapter listenerAdapter) {
SimpleMessageListenerContainer container = new SimpleMessageListenerContainer();
container.setConnectionFactory(connectionFactory);
container.setMessageConverter(Jackson2JsonMessageConverter());
container.setQueueNames(QUEUE2);
container.setMessageListener(listenerAdapter);
container.setAdviceChain(new Advice[]{interceptor()});
container.setConcurrentConsumers(1);
container.setMaxConcurrentConsumers(10);
return container;
}
@Bean
MessageListenerAdapter listenerAdapter() {
return new MessageListenerAdapter(queueService, "consume");
}
答案 0 :(得分:2)
你做的是绝对正确的。如果您需要针对不同队列的不同使用者,则必须配置不同的 var gps = DB.GPS.ToList();
return Ok( new { results = gps });
。您可以考虑使用Spring Integration AMQP通道适配器:https://docs.spring.io/spring-integration/docs/5.0.3.RELEASE/reference/html/amqp.html