【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 服务器重启之后,消息不会丢失。如果只是设置了消息的持久化,不设置队列的持久化,服务器重启之后,队列不存在,消息也会丢失。所以,想要消息的持久化,前提是队列设置了持久化。单单设置消息的持久化毫无意义。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了