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

相关推荐
GetcharZp3 小时前
告别 jq 噩梦!这款 JSON 神器 fx 让你在终端体验“丝滑”的数据操作
后端
小码哥_常4 小时前
告别臃肿!Elasticsearch平替Manticore登场
后端
苍何5 小时前
万字保姆级教程:Hermes+Kimi K2.6 打造7x24h Agent军团
后端
我叫黑大帅5 小时前
为什么map查找时间复杂度是O(1)?
后端·算法·面试
FreeCultureBoy7 小时前
用 phpbrew 管理 php 环境:从安装到多版本切换
后端·php
FreeCultureBoy7 小时前
用 jenv 管理 Java 环境:从安装 JDK 到多版本切换
后端
IT_陈寒7 小时前
Vite的热更新突然失效,原来是因为这个配置
前端·人工智能·后端
考虑考虑7 小时前
SQL语句中的order by可能造成时间重复
数据库·后端·mysql
Pkmer8 小时前
古法编程: 代理模式
后端·设计模式
文心快码BaiduComate8 小时前
Comate搭载Kimi K2.6,长程13h!
前端·后端·程序员