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. 数据目录始终唯一,无新文件夹生成。

相关推荐
神奇小汤圆5 分钟前
面试官当场让我手写Java线程安全工具类,我写完直接拿到了35K offer
后端
久美子1 小时前
Qoder 使用指南:从配置到落地
后端
tyung1 小时前
Go 手写 Wait-Free MPSC 无界队列:SwapPointer 实现多生产者无锁入队
后端·go
张不才1 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
鱼人1 小时前
Redis、网关负载均衡为什么不能用普通取模哈希?
后端
juejin9982 小时前
Claude Code Lab-3(下):三能力 MCP Server
后端
java小白小2 小时前
SpringBoot(07):事务管理——@Transactional 你真的用对了吗?
后端
shepherd1113 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
java小白小3 小时前
SpringBoot(05):Spring Data JPA——用面向对象的方式操作数据库
后端
juejin9983 小时前
Claude Code Lab-2(上):自然语言查库助手
后端