RabbitMQ

一、如何保证消息被消费

RabbitMQ提供了消息补偿机制来保证消息被消费,当一条消费被发送后,到达队列后发给消费者。消费者消费成功后会给MQ服务器的队列发送一个确认消息,此时会有一个回调检测服务监听该接收确认消息的队列,然将消费的消息写入数据库。以上是消息成功被消费时的流程,此时如果消费者没有将消息消费,就不会给服务器发送确认消息了,生产者隔一段时间会延迟发送与之前发送的一模一样的数据到另一个给回调检测服务监听的队列,该服务收到延迟发送的消息后就会去数据库的消息表查询是否有该条消息,但是由于消费者没有消费成功给RabbitMQ服务器发送确认消息,所以数据库里并没有该消息,此时就会让生产者重新发送该消息。但是如果此时延迟消息发送也出了问题,也会触发重发该消息,因为此时会定时检查消费记录里的数据库与生产者发送消息的数据库进行比对,比对之后对未消费成功的消息会进行重发.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值