【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 服务器重启之后,消息不会丢失。如果只是设置了消息的持久化,不设置队列的持久化,服务器重启之后,队列不存在,消息也会丢失。所以,想要消息的持久化,前提是队列设置了持久化。单单设置消息的持久化毫无意义。