Docker Compose 重启 RabbitMQ 数据丢失?

前言

使用 Docker Compose 部署 RabbitMQ 时,容器重启后数据丢失是高频痛点:配置好的队列、交换机、消息全部清空,服务完全重置。

本文结合真实环境命令,直击核心问题,用最简配置解决数据持久化难题。


一、问题现场还原

1. 查看数据目录(关键证据)

执行命令查看 RabbitMQ 数据存储目录:

bash 复制代码
[root@localhost docker-compose-test]# ls rabbitmq-workflow/data/
rabbit@mqbroker-aaa  rabbit@mqbroker-aaa.pid  rabbit@mqbroker-aaa-plugins-expand

核心发现 :RabbitMQ 数据目录命名规则为 rabbit@容器主机名

2. 核心配置(仅保留关键代码)

docker-compose.yaml 修复后的最简关键配置

yaml 复制代码
version: '3.3'
services:
  # RabbitMQ消息队列服务
  rabbitmq-workflow:
    # 🔥 解决数据丢失的核心配置(固定主机名)
    hostname: mqbroker-aaa
    image: rabbitmq:3.9.21-management
    ports:
      - "5672:5672"
      - "15672:15672"

3. 故障现象

未配置 hostname 前:

  1. 启动容器并创建业务队列;
  2. 重启容器后,所有数据丢失
  3. 数据目录自动生成新的随机名称文件夹,旧数据无法加载。

二、根因分析

RabbitMQ 重启丢数据的唯一核心原因:容器主机名不固定!

  1. RabbitMQ 数据目录强依赖容器内部主机名生成;
  2. Docker 默认主机名为随机容器ID,重启必变;
  3. 主机名变更 → RabbitMQ 无法识别旧数据目录 → 新建目录 → 数据丢失。

三、终极解决方案

只需要一行配置,固定容器内部主机名,彻底解决问题:

yaml 复制代码
hostname: mqbroker-aaa

配置后,容器重启主机名永久不变,RabbitMQ 始终读取同一数据目录。


四、验证修复效果

  1. 重启容器
bash 复制代码
docker-compose down && docker-compose up -d
  1. 查看固定主机名
bash 复制代码
docker exec rabbitmq-workflow hostname

输出:mqbroker-aaa(固定不变)

  1. 数据目录始终唯一,无新文件夹生成。

相关推荐
REDcker13 小时前
个人博客网站建设指南 Markdown资产化与静态站选型部署
前端·后端·博客·markdown·网站·资产·建站
Supersist13 小时前
【设计模式03】使用模版模式+责任链模式优化实战
后端·设计模式·代码规范
Fox爱分享14 小时前
字节二面:10亿数据毫秒级查手机尾号后4位,答不出“异构索引”直接挂?
java·后端·面试
折哥的程序人生 · 物流技术专研14 小时前
《Java面试85题图解版(二)》进阶深化上篇:并发编程 + JVM
java·开发语言·后端·面试
Mahir0814 小时前
MySQL 数据一致性的基石:三大日志( redo log/undo log/binlog)与两阶段提交(Prepare 阶段和Commit 阶段)深度解密
数据库·后端·mysql·面试
L0CK14 小时前
Redis 内存淘汰策略
后端
zhengzizhe14 小时前
ReBAC 与 Google Zanzibar:权限系统的未来
后端·架构
用户83562907805114 小时前
使用 Python 自动创建 Excel 折线图
后端·python
梅兮昂14 小时前
Cloudflare Tunnel 实践教程
后端
倒流时光三十年14 小时前
PostgreSQL VACUUM 清理机制详解
后端