写点什么

2023-07-08:RabbitMQ 如何做到消息不丢失?

  • 2023-07-08
    北京
  • 本文字数:480 字

    阅读完需:约 2 分钟

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 属性指定备份队列。



发布于: 刚刚阅读数: 3
用户头像

公众号:福大大架构师每日一题 2021-02-15 加入

公众号:福大大架构师每日一题

评论

发布
暂无评论
2023-07-08:RabbitMQ如何做到消息不丢失?_福大大架构师每日一题_福大大架构师每日一题_InfoQ写作社区