2023-07-08:RabbitMQ 如何做到消息不丢失?
2023-07-08:RabbitMQ 如何做到消息不丢失?
答案 2023-07-08:
1.持久化
发送消息时设置 delivery_mode 属性为 2,使消息被持久化保存到磁盘,即使 RabbitMQ 服务器宕机也能保证消息不丢失。同时,创建队列时设置 durable 属性为 True,以确保队列也被持久化保存。
2.确认机制
消费者通过 basic.ack 命令向 RabbitMQ 服务器确认已经消费了消息。如果消费者处理消息时发生错误或宕机,RabbitMQ 会重新将消息发送给其他消费者。RabbitMQ 在接收到消费者确认消息前会将消息保存在内存中,在确认后才会删除消息。
3.发布者确认
RabbitMQ 支持发布者确认机制,即发布者在将消息发送到队列后,等待 RabbitMQ 服务器的确认消息。成功保存到队列的消息会返回确认消息给发布者,如果无法保存则返回 Nack(Negative Acknowledgement)消息。通过发布者确认机制,可以确保消息成功发送到 RabbitMQ 服务器。
4.备份队列
RabbitMQ 支持备份队列(Alternate Exchange)机制,即在消息发送到队列之前,先将消息发送到备份队列。如果主队列无法接收消息,RabbitMQ 会将消息发送到备份队列中。备份队列通常是一个交换机,在创建队列时可以通过 x-dead-letter-exchange 属性指定备份队列。
版权声明: 本文为 InfoQ 作者【福大大架构师每日一题】的原创文章。
原文链接:【http://xie.infoq.cn/article/2e437413f16dbba04060d6533】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论