繁体   English   中英

在选择Amqp / RabbitMQ队列(Spring AMQP)之前如何“检查”

[英]How to 'check' before picking off the Amqp/ RabbitMQ Queue (Spring AMQP)

场景:微服务从RabbitMQ队列中提取一条消息,将其转换为对象,然后微服务对外部服务进行REST调用。

它要处理成千上万的此类消息,如果我们知道外部Rest服务已关闭,有没有办法告诉我的用户不要从队列中提取消息?

我知道一旦收到一条消息就可以重试一条单独的消息,但是如果我知道它已断开,我什至不想捡起来。 我不想处理DLQ中的数千条消息。

感觉上也像是断路器的设计模式,但是我找不到如何使用AMQP实施的任何具体示例。

额外信息:SpringBoot应用程序,使用spring amqp进入RabbitMQ。

提前致谢

您可以停止并启动消息侦听器容器。

如果使用离散容器,则可以停止/启动容器bean。

如果使用@RabbitListener ,请提供一个id属性,并在RabbitListenerEndpointRegistry bean中进行连接。

然后registry.getMessageListenerContainer(myId).stop();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM