10 RabbitMQ 高级特性ConsumerAck、TTL、DLX

一、ConsumerAck

消费端收到消息后的确认方式常用的有两种:

  •          自动确认:       acknowledge="none"
  •          手动确认:      acknowledge="manual"

其中自动确认是指当消息一旦被Consumer收到,则自动确认收到,并将message从RabbitMQ的消息缓存中移除。

但是在实际业务处理中,很有可能消息接收到,但是业务处理出现了异常,那么该消息就会消失

若我们采用手动确认的方式,就不会出现该问题:

  •         业务处理成功后,调用channel.basicAck()手动签收
  •         业务处理失败后,调用channel.basicNack()方法让其自动重新发送消息

二、TTL

TTL全称为Time To Live,也就是存活时间。

当消息达到存活时间还没有被消费就会被自动清除。

RabbitMQ可以对消息设置存活时间,也可以对整个队列设置存活时间。存活时间少的起到制约作用,决定总的存活时间。

 三、DLX

死信队列:全称Dead Letter Exchange(死信交换机),当消息成为Dead Message后可以被重新发到一个死信交换机,这个交换机就是DLX。

消息在三种情况下会成为死信:

  •         队列的消息长度达到限制,则后面进来的消息都会成为死信
  •         消费者拒绝接收消息,basicNack,并且不把消息重新放回原队列中requeue=false
  •         原队列存在消息过期设置,消息到达超时时间未被消费

队列绑定死信交换机主要通过两个参数实现:

        x-dead-letter-exchange和x-dead-letter-routing-key

 

四、延迟队列

在RabbitMQ中常用TTL+DLX实现延迟队列

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值