【转载】关于RabbitMQ的消息持久性
2023-09-14 08:59:45 时间
在消息队列 RabbitMQ 入门介绍里,描述了 RabbitMQ 的持久性设置。在设置持久化后,消息保存在磁盘上,即使 RabbitMQ 重启或服务器重启,消息都不会丢失。
RabbitMQ 支持消息的持久化,也就是数据写在磁盘上,为了数据安全考虑,我想大多数用户都会选择持久化。消息队列持久化包括3个部分:
(1)exchange 持久化,在声明时指定 durable = 1
(2)queue 持久化,在声明时指定 durable = 1
(3)消息持久化,在投递时指定 delivery_mode = 2(1 是非持久化)
如果 exchange 和 queue 都是持久化的,那么它们之间的 binding 也是持久化的。如果exchange 和 queue 两者之间有一个持久化,一个非持久化,就不允许建立绑定(这句话说的有问题,实际情况中经常出现非持久化的 queue 绑定到持久化 exchange 上的情况。个人觉得其意思应该是:当两者并非都是持久化时,其对应的 binding 就无法得到恢复)。
但是,即使设置了持久化,也不能百分百保证消息不会丢失。有很小的概率在 RabbitMQ 接受到消息后,还没来得及写到磁盘,就发生重启了。另外,RabbitMQ 也不会对每一个消息执行 fsync(2),消息可能仅仅写入到缓存,还没来得及 flush 到硬件存储。因此 RabbitMQ 的持久性设置并非足够安全,对于普通的工作队列也许够用了。如果需要加强的安全保证,可以把发布消息的代码封装在事务里。
springcloud:springboot整合RabbitMQ|RabbitMQ保证消息可靠性(三) 上一章我们讲解了rabbitmq的四种交换机类型、七种通讯方式。本章我们将整合springboot来向大家完整演示rabbitmq的使用,并说明如何保证消息的可靠性。
相关文章
- RabbitMQ模拟消息队列群发邮件
- kafka和rabbitmq和activemq区别_kafka消息持久化处理
- dubbo源码学习之服务端接收消息 负载均衡(四)
- 如何使用arthas抓包确认RocketMQ发送消息耗时慢
- 字节跳动3-3大牛力荐!RabbitMQ实战指南:消息队列面试必刷手册
- RabbitMQ——队列消息数
- RabbitMQ消息为什么变成了数字呢?
- 消息队列RabbitMQ核心:简单(Hello World)模式、队列(Work Queues)模式、发布订阅模式
- RabbitMQ 消息应答与发布
- 消息队列:第五章:RabbitMQ的使用
- 使用 Excel cdata addin 连接 SAP ABAP 系统时遇到错误消息 Unable to connect to SAP system
- 18-RabbitMQ高级特性-消息追踪
- 20-RabbitMQ应用问题-消息幂等性保障
- RabbitMQ 延迟消息实战
- SQLServer 错误 17660 正在启动,但不会进行恢复。 这只是一条信息性消息。 不需要任何用户操作。 故障 处理 修复 支持远程
- phpredis提高消息队列的实时性方法(推荐)
- RabbitMQ详解(二)——消息通信的概念大数据
- activemq获取消息的详细信息详解编程语言
- HTTP 状态消息
- Linux消息队列:实现强大的IPC通信(linuxmsgq)
- 探索Redis与RabbitMQ的应用之美(redis和rabbitmq)
- 汪丛青没透露HTC Vive的销量,但我们从别处得到一些消息
- Linux 卸载RabbitMQ的经验分享(linux卸载rabbitmq)
- Oracle消息队列的实际应用(oracle使用消息队列)
- 深入了解Oracle AQ令人瞩目的消息排队解决方案(oracle aq是什么)
- 消息称Switch Pro年底发布:性能全面升级、屏幕依然7英寸OLED