RabbitMQ高级篇之MQ可靠性 数据持久化

文章目录

      • 消息丢失的原因分析
      • 内存存储的缺陷
      • 如何确保 RabbitMQ 的消息可靠性?
      • 数据持久化的三个方面
      • 持久化对性能的影响
      • 持久化实验验证
      • 性能对比
      • Spring AMQP 默认持久化
      • 总结

消息丢失的原因分析

RabbitMQ 默认使用内存存储消息,但这种方式带来了两个主要问题:

  • 内存不是永久存储:内存中的数据会随着 RabbitMQ 的重启丢失。如果消息存储在内存中,一旦 MQ 宕机或重启,所有未持久化的消息都会丢失。
  • 内存空间有限:如果消费者处理消息的速度较慢,而生产者发送消息的速度过快,MQ 会堆积大量的消息,导致内存占满,最终可能导致 MQ 阻塞。当内存满时,RabbitMQ 会尝试将内存中的部分消息写入磁盘,但此操作非常耗时,会导致 MQ 无法处理更多的消息,进而发生阻塞。

内存存储的缺陷

  • 消息丢失:因为内存不是持久化存储,当 RabbitMQ 重启时,内存中的所有数据(包括交换机、队列、消息)都将丢失。
  • 性能下降与阻塞:内存满时,消息需要被转移到磁盘,磁盘的写入速度慢,导致消息处理速度下降。如果消息堆积,MQ 会阻塞,不能继续接收或处理消息,严重影响系统的实时性。



如何确保 RabbitMQ 的消息可靠性?

要确保消息不丢失并且能够持续处理,需要采取数据持久化的措施。数据持久化意味着将消息、队列和交换机的元数据存储在磁盘中,确保即使 RabbitMQ 重启,消息也不会丢失。



数据持久化的三个方面

为了确保数据在 RabbitMQ 中的可靠性,需要对以下三方面进行持久化配置:

  1. 交换机持久化
  • 换机在 RabbitMQ 中负责路由消息。如果交换机丢失,消息会丢失,因此交换机必须持久化。
  • 默认情况下,RabbitMQ 创建的交换机是持久化的。可以在创建交换机时,通过设置 durable=true 来指定交换机的持久化属性。



  1. 队列持久化
  • 队列存储消息。如果队列丢失,所有未处理的消息都会丢失,因此队列也必须持久化。
  • 与交换机类似,队列的 durable 属性应该设置为 true,这样队列会在 RabbitMQ 重启后保留下来。



  1. 消息持久化
  • 即使交换机和队列是持久化的,如果消息本身没有被持久化,消息依然会丢失。
  • 在发送消息时,通过设置 delivery mode=persistent 来将消息标记为持久化。这样,消息就会被存储到磁盘中,即使 RabbitMQ 重启,消息也不会丢失。


持久化对性能的影响

  • 非持久化消息
    • 如果消息没有设置持久化,RabbitMQ 会把消息存储在内存中。当内存满时,它会将数据写入磁盘(称为 paged out),这会导致性能下降,因为磁盘写入操作较慢。
    • 这种模式下,MQ 可能会出现阻塞,即消息发送速率骤降,甚至停止处理消息。
  • 持久化消息
    • 如果消息是持久化的,即每发送一条消息都立即写入磁盘,不会等待内存满了才写。这种方式保证了消息不会丢失,同时避免了 paged out 导致的阻塞问题。
    • 持久化消息的写入速度相对较慢,但性能波动较小,不会出现阻塞。虽然会有一些性能开销,但不会像非持久化消息那样,处理速度大幅下降。



持久化实验验证

  • 非持久化消息发送
    • 当发送大量(例如 100 万条)非持久化消息时,如果队列或内存满了,RabbitMQ 会将内存中的消息写入磁盘。在此过程中,消息处理速度会显著下降,甚至停滞,导致性能严重下降。
    • paged out 操作会导致消息的处理速度一度降为零,之后才恢复。



  • 持久化消息发送
    • 当发送持久化消息时,消息不仅存储在内存中,还会立即写入磁盘。因此,无论内存如何变化,磁盘中的数据都能保持一致,不会发生消息丢失。
    • 持久化模式下,即使有大量消息需要处理,RabbitMQ 仍然能够保持较高的处理速率,没有明显的性能下降或阻塞。



性能对比

  • 非持久化模式:发送大量消息时,随着内存满了,系统会进行 paged out,导致性能波动,速率降低到零,造成阻塞。
  • 持久化模式:每条消息都会立即持久化到磁盘,因此没有发生内存满了才写入的情况,性能保持稳定,处理速度平稳。



Spring AMQP 默认持久化

  • Spring AMQP 配置:默认情况下,Spring AMQP 创建的队列和交换机都是持久化的,发送的消息也是持久化的。因此,开发者不需要做额外的配置,默认行为即可保证消息的可靠性。

总结

为了确保 RabbitMQ 的消息可靠性,应采用以下措施:

  1. 确保交换机、队列和消息都做持久化,避免数据丢失。
  2. 通过 Spring AMQP 默认配置,可以确保消息的可靠性,但需要注意消息持久化的性能开销。
  3. 持久化虽然会带来一定的性能开销,但比起非持久化模式导致的阻塞问题,持久化更有利于系统的稳定性和可靠性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/951537.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Openssl1.1.1s rpm包构建与升级

rpmbuild入门知识 openssh/ssl二进制升级 文章目录 前言一、资源准备1.下载openssh、openssl二进制包2.安装rpmbuild工具3.拷贝源码包到SOURCES目录下4.系统开启telnet,防止意外导致shh无法连接5.编译工具安装6.补充说明 二、制作 OpenSSL RPM 包1.编写 SPEC 文件2.…

【Unity3D】apk加密(global-metadata.dat加密)

涉及:apk、aab、global-metadata.dat、jks密钥文件、APKTool、zipalign 使用7z打开apk文件观察发现有如下3个针对加密的文件。 xxx.apk\assets\bin\Data\Managed\Metadata\global-metadata.dat xxx.apk\lib\armeabi-v7a\libil2cpp.so xxx.apk\lib\arm64-v8a\libil…

[免费]微信小程序(高校就业)招聘系统(Springboot后端+Vue管理端)【论文+源码+SQL脚本】

大家好,我是java1234_小锋老师,看到一个不错的微信小程序(高校就业)招聘系统(Springboot后端Vue管理端),分享下哈。 项目视频演示 【免费】微信小程序(高校就业)招聘系统(Springboot后端Vue管理端) Java毕业设计_哔哩哔哩_bilibili 项目介绍…

RNN心脏病预测-Pytorch版本

本文为为🔗365天深度学习训练营内部文章 原作者:K同学啊 一 导入数据 import numpy as np import pandas as pd import torch from torch import nn import torch.nn.functional as F import seaborn as sns from sklearn.preprocessing import Standard…

科普CMOS传感器的工作原理及特点

在当今数字化成像的时代,图像传感器无疑是幕后的关键 “功臣”,它宛如一位神奇的 “光影魔法师”,通过光电效应这一奇妙的物理现象,将光子巧妙地转换成电荷,为图像的诞生奠定基础。而在众多类型的图像传感器中&#xf…

Ubuntu 18.04 解决screen无法滚屏的问题

Ubuntu 18.04 解决screen无法滚屏的问题_ubuntu screen 无法上滑-CSDN博客文章浏览阅读2.7k次,点赞2次,收藏3次。在etc/screenrc中加入termcapinfo xterm* ti:te重新进入screen的sessionscreen -d -r XXX_ubuntu screen 无法上滑https://blog.csdn.net/w…

2025年01月09日Github流行趋势

1. 项目名称:khoj 项目地址url:https://github.com/khoj-ai/khoj项目语言:Python历史star数:22750今日star数:1272项目维护者:debanjum, sabaimran, MythicalCow, aam-at, eltociear项目简介:你…

Spring boot接入xxl-job

Spring boot接入xxl-job 导入maven包加入配置增加配置类创建执行器类&#xff08;写job的业务逻辑&#xff09;去控制台中配置job 导入maven包 <dependency><groupId>com.xuxueli</groupId><artifactId>xxl-job-core</artifactId><version>…

Cglib动态代理中method.invoke与methodProxy.invokeSuper区别浅尝

前段时间看了黑马Spring教程中&#xff0c;有期视频讲解Cglib动态代理。 代码如下图&#xff1a; 可以看到调用目标对象的方法代码为&#xff1a; method.invoke(target,objects);在其他地方看到的此处代码是&#xff1a; methodProxy.invokeSuper(o,objects);注意&#xff…

【Linux 之一 】Linux常用命令汇总

Linux常用命令 ./catcd 命令chmodclearcphistoryhtoplnmkdirmvpwdrmtailunamewcwhoami 我从2021年4月份开始才开始真正意义上接触Linux&#xff0c;最初学习时是一脸蒙圈&#xff0c;啥也不会&#xff0c;啥也不懂&#xff0c;做了很多乱七八糟&#xff0c;没有条理的笔记。不知…

NO.3 《机器学习期末复习篇》以题(问答题)促习(人学习),满满干huo,大胆学大胆补!

目录 &#x1f50d; 1. 对于非齐次线性模型 &#xff0c;试将其表示为齐次线性模型形式。 ​编辑 &#x1f50d; 2. 某汽车公司一年内各月份的广告投入与月销量数据如表3-28所示&#xff0c;试根据表中数据构造线性回归模型&#xff0c;并使用该模型预测月广告投入为20万元时…

Javascript算法——贪心算法(一)

贪心算法详解&#xff08;JavaScript&#xff09;&#xff08;局部最优->全局最优&#xff09; 贪心算法&#xff08;Greedy Algorithm&#xff09;是一种在每一步选择中都采取当前状态下的最优选择&#xff08;局部最优&#xff09;的算法设计方法。通过局部最优解的累积&…

【Vue】分享一个快速入门的前端框架以及如何搭建

先上效果图: 登录 菜单: 下载地址: 链接&#xff1a;https://pan.baidu.com/s/1m-ZlBARWU6_2n8jZil_RAQ 提取码&#xff1a;ui20 … 主要是可以自定义设置token,更改后端请求地址较为方便。 应用设置: 登录与token设置: 在这里设置不用登录,可以请求的接口: request.js i…

jdk8升级JDK21(Springboot2.7.18升级Springboot3.4.0)

目录 背景&#xff1a; 一、maven升级 二、代码改造 2.1 javax替换为jakarta 2.2 swagger2升级swagger3相关更新 2.2.1 新增SpringDocConfig配置类 2.2.2 全局代码更新 2.2.3 全局代码替换&#xff08;普通正则替换&#xff09; 2.3 Mybatis Plus升级 2.4 logback.xm…

数据库(3)--针对列的CRUD操作

1.Create 新增 语法&#xff1a; insert into 表名 &#xff08;列名&#xff09;values &#xff08;列&#xff09;... 创建一个学生表用于演示&#xff1a; create table if not exists student( id bigint comment 编号, name varchar(20) comment 姓名 ); 1.1直接增加…

加速科技荣获“浙江省企业研究院”认定

近日&#xff0c;浙江省经济和信息化厅公布“2024年认定&#xff08;备案&#xff09;省级企业研发机构名单”。经过多轮严格评审和公示&#xff0c;加速科技荣获“省企业研究院”认定。这是加速科技继获国家级专精特新“小巨人”企业认定荣誉后的又一里程碑。 “浙江省企业研究…

leetcode:1784. 检查二进制字符串字段(python3解法)

难度&#xff1a;简单 给你一个二进制字符串 s &#xff0c;该字符串 不含前导零 。 如果 s 包含 零个或一个由连续的 1 组成的字段 &#xff0c;返回 true​​​ 。否则&#xff0c;返回 false 。 示例 1&#xff1a; 输入&#xff1a;s "1001" 输出&#xff1a;fa…

双向列表的实现(C++)

一.实现思路 主要是一个空间存储一个数值&#xff0c;然后为了索引后面的数据单元和前面的数据单元&#xff0c;所以在每个空间里面还要存储前面和后面数据单元的指针&#xff0c;就形成了每个数据单元 后面就是要管理的是双向列表的头结点和尾节点&#xff0c;方便实现后面的头…

【前端开发常用网站汇总-01】

1、仿mac界面代码截图 https://codeimg.io/?utm_sourceappinn.com 2、可视化大屏汇总(在线Demo) https://www.xiongze.net/viewdata/index.html 3、在线Photoshop(实现简单P图) https://ps.gaoding.com/#/ 4、在线生成ico图标(png转icon文件) https://www.bitbug.net/in…

腾讯云AI代码助手编程挑战赛-百事一点通

作品简介 百事通问答是一款功能强大的智能问答工具。它依托海量知识储备&#xff0c;无论你是想了解生活窍门、学习难点&#xff0c;还是工作中的专业疑惑&#xff0c;只需输入问题&#xff0c;就能瞬间获得精准解答&#xff0c;以简洁易懂的方式呈现&#xff0c;随时随地为你…