rabbitmq数据恢复

问题背景:

最近遇到了生产故障,原因是rabbit的主机被修改,重启后导致rabbitmq的数据丢失,为此整理了RabbitMQ 数据恢复指南,专为应对因主机名变更、节点身份丢失、误删数据或配置错误 等导致 RabbitMQ 无法识别原有数据的场景而设计。重点保障队列消息、用户、权限、策略、交换机等核心数据可恢复。

方式1:

通过数据备份文件恢复:
实现方式:

做任何变更前,对rabbitmq集群提前进行备份。然后如果集群发生数据重构,可以及时恢复之前的数据。
备份步骤:

1、打开rabbitmq的overview界面,选择Export definitions 下载此时的数据。

从页面上可以看到集群当前的交换机数量是:23 队列: 57 等数据。

2、rabbit_localhost_2025-12-4.json文件是包含队列交换机、虚拟机、队列的备份数据。

恢复步骤:

1、模拟主机修改故障发生,主机名发生修改。

从图片上我们可以看到服务器的主机名发生了修改。存储目录发生了改变,rabbitmq用户不存在。

2、此时我们需要新建用户导入之前已经备份的数据,进行恢复。

bash 复制代码
#添加用户
rabbitmqctl add_user repairuser QWEs1seSDv35bdl
# 设置为管理员(可选)
rabbitmqctl set_user_tags repairuser administrator
# 授权访问默认 vhost "/"
rabbitmqctl set_permissions -p / repairuser ".*" ".*" ".*"

3、登录到web页面,此时无任何队列。无业务的交换机,和虚拟机。

4、手动导入我们之前备份的数据,进行恢复。

Overview - import definitions -选择文件进行导入

出现以下标识代表成功,然后进行数据验证。

5、数据验证,验证账号密码

复制代码
#查看用户
rabbitmqctl list_users
#查看交换机
rabbitmqctl list_exchanges
#查看虚拟机
rabbitmqctl list_vhosts
#查看权限
rabbitmqctl list_permissions
方式2:

通过修改旧的主机名进行数据恢复:

此方式建立在无备份数据的情况进行数据恢复,达到数据数据一致。

步骤 1:停止 RabbitMQ

复制代码
systemctl stop rabbitmq-server

步骤 2:恢复原始主机名(最佳方案)

复制代码
#改回原主机名(原名为 prod-ims-message-node81)
hostnamectl set-hostname prod-ims-message-node81

echo "127.0.0.1 prod-ims-message-node81" >> /etc/hosts

✅ 这是最安全的方式,让 RabbitMQ 认出自己。

方式3:

通过增加配置参数进行恢复:

存储目录无需变更,我们只需要在/etc/rabbitmq/目录编辑rabbitmq-env.conf文件,增加我们之前的旧主机名即可

1、编辑rabbitmq-env.conf,如果没有需要新建这个文件,prod-ims-message-node81是旧的主机名

bash 复制代码
NODENAME=rabbit@prod-ims-message-node81

2、增加hosts文件的解析,不然启动也会报错主机名无法解析。

bash 复制代码
echo "127.0.0.1 prod-ims-message-node81" >> /etc/hosts

3、重启rabbitmq

bash 复制代码
systemctl restart rabbitmq-server.service

如果没有其他问题,启动是正常的

4、检查数据并验证账号密码队列等

相关推荐
咖啡星人k11 小时前
MonkeyCode 开源协作指南:如何让分布式团队高效使用AI编程
分布式·开源·ai编程·monkeycode
阿坤带你走近大数据11 小时前
如何保证kafka中的数据一致性
分布式·kafka
凯源智能11 小时前
高寒地区分布式光伏箱变测控系统落地实战
分布式·箱变测控·光伏箱变测控装置·箱变监控系统
逆境不可逃11 小时前
深入理解 SingleFlight:从单机到分布式的请求合并方案全解析
分布式·wpf
阿坤带你走近大数据11 小时前
Kafka中的分区概念
分布式·kafka
fQ9F9I58m13 小时前
Redis 分布式锁进阶第三百一十一篇
数据库·redis·分布式
mqiqe14 小时前
面试题-Zookeeper 面试篇
分布式·zookeeper·面试
极客先躯14 小时前
高级java每日一道面试题-2026年02月07日-实战篇[Docker]-如何使用存储插件(如 NFS、Ceph)?
运维·分布式·容器·自动化·文件·插件·高可用
西凉的悲伤15 小时前
redis和数据库实现分布式锁
java·数据库·redis·分布式
爱吃牛肉的大老虎15 小时前
Kafka集群之抛弃 Zookeeper
分布式·zookeeper·kafka