RabbitMQ-数据持久化

一、持久化类型

1、交换机持久化(SpringAMQP默认)

2、队列持久化(SpringAMQP默认)

3、消息持久化

二、消息持久化

1、纯内存操作

如果采用纯内存操作,那么消息存储达到队列的上限之后,会有一个page out操作,这个操作是将队列中已经有的一部分MQ消息转移到磁盘,给队列腾出空间,使得队列能够继续接收MQ消息,这个转移MQ消息的过程是一个阻塞的过程,转移过程中,队列无法接收MQ消息。

2、持久化消息

SpringAMQP默认采用这种方式,这种方式需要将MQ消息入队的同时,也写一份进入到磁盘中,但是与Page out操作有一定区别,不会阻塞;当队列满了之后,会有一次清空内存的操作,这个操作会使得队列接收消息变慢,但是不至于阻塞。

3、LazyQueue

惰性队列,消息直接写入到磁盘,内存中会保留最近的一部分消息,很少的一部分;当消费者需要消息时,才会到到磁盘中去读取;3.12版本之后,队列都是LazyQueue的模式,无法更改。

相关推荐
RFG20122 小时前
20、详解Dubbo框架:消费方如何动态获取服务提供方地址?【微服务架构入门】
java·人工智能·后端·微服务·云原生·架构·dubbo
zjttsh3 小时前
Linux下安装Redis
java
TimberWill3 小时前
SpringBoot整合Srping Security实现权限控制
java·spring boot·后端
Renhao-Wan4 小时前
Java 算法实践(四):链表核心题型
java·数据结构·算法·链表
_codemonster5 小时前
JavaWeb开发系列(六)JSP基础
java·开发语言
万邦科技Lafite5 小时前
淘宝店铺所有商品API接口实战指南
java·数据库·mysql
jjjxxxhhh1236 小时前
【加密】-AES与对称加密
java·服务器·网络
临水逸6 小时前
飞牛fnos 2025 漏洞Java跨域URL浏览器
java·开发语言·安全·web安全
yaoxin5211236 小时前
324. Java Stream API - 实现 Collector 接口:自定义你的流式收集器
java·windows·python
H Corey6 小时前
数据结构与算法:高效编程的核心
java·开发语言·数据结构·算法