RabbitMQ—如何实现高可靠消息消费逻辑

本文介绍了RabbitMQ中处理消息消费异常的策略,包括因不当ack处理导致的问题,如unack状态、死循环和内存泄露。通过设置重试队列和死信队列,实现消息的延时投递和最大重试次数限制,以降低下游服务压力并提高系统的容错性。当消息无法消费时,将其发送到死信队列以便后续审计和处理。
摘要由CSDN通过智能技术生成

RabbitMQ消费过程中对消息ack处理不当,经常会带来一下的问题:

  1.  消息ack异常造成消息处于unack状态,一直pending得不到正常处理;
  2.  依赖rabbitmq自身的nack的enqueue逻辑,让消息重新入列,反复的处理,造成死循环;大量出现时会引起rabbitmq server端的内存泄露问题(3.5.x版,3.6.x之后没有测试过);
  3. 消息快速重试造成下游消费的负载严重过高,缺乏较好的容错机制;
  4. 重试消息进入同一个queue,对消费延迟要求比较苛刻的程序,会造成一定的延时影响,特别大量重试情况下;

为解决以上问题:
        1.   封装用户直接调用ack接口,而是由用户处理完逻辑后,通过返回状态值k来进行内部ack处理比如:比如重试,丢弃,消费完成等状态;
        2.   消费消息成功时,内部提交直接 basicack完成就好;
        3.   消费失败时,如果需要重试,则将消息发回到独立的重试队列(内部declare的一个队列%RETRY%queue),该队列的消息发布时有一定的特殊性,后续会有介绍;
        4.   消费失败,但不需要重试,直接采用basicNack(ackIdx, false, false)丢弃该消息;

针对以上重试机制,采用不同延时的等级来进行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值