【RabbitMQ 笔记】— 持久化

RabbitMQ 的持久化分为三个部分:

  • 交换器的持久化
  • 队列的持久化
  • 消息的持久化

交换器的持久化

交换器的持久化是在声明交换器时将 durable 设为 true。如果交换器没有设置持久化,那么 RabbitMQ 宕机重启后,交换器相关的元数据会丢失,不过相关的消息不会丢失,只是不能将消息发送到这个交换器。对于一个长期使用的交换器的来说,建议将其设置为持久化。

队列的持久化

队列的持久化是在声明队列的时候设置 durable 为 true。如果队列不设置持久化,那么 RabbitMQ 服务器重启之后,相关队列的元数据会丢失,相关的消息也会丢失。想想也是,队列都没了,消息能存到哪。

消息的持久化

队列的持久化只能保证相关队列的元数据不会丢失,但并不能保证消息的持久化。设置消息的持久化是将消息的投递模式(BasicProperties 中 deliveryMode 属性)设置为 2 来完成的。之前代码中BasicProperties PERSISTENT_TEXT_PLAIN是封装了这个属性

/** Content-type "text/plain", deliveryMode 2 (persistent), priority zero */
public static final BasicProperties PERSISTENT_TEXT_PLAIN =
    new BasicProperties("text/plain",
                        null,
                        null,
                        2,
                        0, null, null, null,
                        null, null, null, null,
                        null, null);

设置了队列和消息的持久化,当 RabbitMQ 服务器重启之后,消息不会丢失。如果只是设置了消息的持久化,不设置队列的持久化,服务器重启之后,队列不存在,消息也会丢失。所以,想要消息的持久化,前提是队列设置了持久化。单单设置消息的持久化毫无意义。

参考

《RabbitMQ实战指南》

posted @ 2022-06-09 13:33  Tailife  阅读(531)  评论(0编辑  收藏  举报