rabbitmq消费端确认机制

rabbitmq消费端确认机制

为了保证消息从队列可靠的到达消费者,rabbitmq提供了消息确认机制(message acknowledgement)。

消息确认

消费者在订阅队列时,可以指定autoAck参数:

  • autoAck等于true时,rabbitmq会自动把发送出去的消息置为确认,然后从内存(或者磁盘)中删除,而不管消费者是否真正的消费到了消息
  • autoAck等于false时,rabbitmq会等待消费者显示的回复确认信号后才从内存(或者磁盘)中删除消息。此时消费者有足够的时间去处理消息,不用担心消费者进程挂掉后消息丢失的问题

消息拒绝

消费者如果接收到消息后,想明确的拒绝而不是确认,可以通过:

channel.basicReject(deliveryTag, requeue);

其中deliveryTag可以看作是消息的编号,requeue为true时,rabbitmq会重新将这条消息加入队列,以便发送下一个订阅的消费者;如果requeuefalse时,rabbitmq会立刻把消息从队列中删除,而不会把它发送给新的消费者

channel.basicReject方法一次性只能拒绝一条消息,如果要指批量拒绝,可以调用:

channel.basicNack(deliveryTag, multiple, requeue)

multiple为false时,只能描绘一条消息,作用和channel.basicReject一样;multiple为true时,表示拒绝deliveryTag编号之前所有未被当前消费者确认的消息

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值