0

0

为什么在 RabbitMQ 中设置 delivery_mode 为 1 时消息仍会被写入磁盘?

心靈之曲

心靈之曲

发布时间:2025-03-22 09:30:25

|

880人浏览过

|

来源于php中文网

原创

为什么在 rabbitmq 中设置 delivery_mode 为 1 时消息仍会被写入磁盘?

RabbitMQ 消息持久化设置失效的疑难排查

在 RabbitMQ 中,delivery_mode 属性控制消息持久化方式。设置为 1 表示消息仅存储在内存中,但实际应用中,即使设置了 delivery_mode: 1,消息有时仍会被写入磁盘,导致性能下降。

本文分析一个案例:用户发现即使设置 delivery_mode: 1,消息投递速度仍然很慢,并且内存中消息数量(In memory)与持久化消息数量(Persistent)相等。这与预期不符,因为非持久化消息不应该写入磁盘。

用户已确认消息的 delivery_mode 正确设置,排除了代码问题。考虑到该队列由 Kubernetes 管理员部署,用户怀疑是服务器配置问题。在 Docker 环境下测试,问题未重现,进一步佐证了此猜测。

用户提出了两种可能:

MakeSong
MakeSong

AI音乐生成,生成高质量音乐,仅需30秒的时间

下载
  1. 服务器内存不足。
  2. RabbitMQ 启用了某些特殊特性。

关键观察:无论 delivery_mode 为 1 或 2,In memoryPersistent 值始终相等。

社区成员给出了一个合理的解释:启用 Stream 队列。Stream 队列是 RabbitMQ 的一种特殊队列类型,默认启用持久化,即使 delivery_mode 设置为 1,消息也会写入磁盘。

因此,如果遇到类似问题,请检查是否使用了 Stream 队列。如果是,则需要调整相关配置,例如禁用 Stream 队列的持久化或使用普通队列,以确保消息处理符合预期。 这将有助于提升消息投递速度,避免因非预期持久化导致的性能瓶颈。

相关专题

更多
rabbitmq和kafka有什么区别
rabbitmq和kafka有什么区别

rabbitmq和kafka的区别:1、语言与平台;2、消息传递模型;3、可靠性;4、性能与吞吐量;5、集群与负载均衡;6、消费模型;7、用途与场景;8、社区与生态系统;9、监控与管理;10、其他特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

200

2024.02.23

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

249

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

494

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

398

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

436

2024.04.08

Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务
Golang云原生微服务Kubernetes_Golang怎么集成Kubernetes开发云原生服务

Golang云原生微服务Kubernetes (K8s) 是指 使用 Go 语言(Golang)编写的云原生微服务,并利用 Kubernetes 平台进行容器化部署、自动化管理、弹性伸缩和高效编排的一整套现代应用架构方案。

23

2025.12.22

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

10

2026.01.12

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

102

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

60

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
光速学会docker容器
光速学会docker容器

共33课时 | 1.9万人学习

Docker 17 中文开发手册
Docker 17 中文开发手册

共0课时 | 0人学习

极客学院Docker视频教程
极客学院Docker视频教程

共33课时 | 17.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号