A服务器备份rabbitmq持久化目录到B服务器,不显示mq队列消息

场景:在A服务器上docker启动mq服务,在mq服务器上恢复服务,结果队列消息丢失问题

1.备份持久化文件

docker inspect 容器id

bash 复制代码
      "Mounts": [
            {
                "Type": "bind",
                "Source": "/data/containers/rabbitmq/data",
                "Destination": "/var/lib/rabbitmq",
                "Mode": "rw",
                "RW": true,
                "Propagation": "rprivate"
            }
bash 复制代码
# 使用tar压缩文件
tar -zcvf rabbitmq.tar.gz /data/containers/rabbitmq/data

将压缩文件发送到备用服务器103

2.新服务器启动mq服务

1.解压文件

解压文件到当前文件夹

bash 复制代码
tar -xzvf rabbitmq.tar.gz

查看文件

bash 复制代码
(base) [root@centos-3 rabbitmq]# ls
config  data  docker-compose.yml

docker-compose文件内容如下

bash 复制代码
services:
  rabbitmq:
    container_name: rabbitmq
    image: registry.cn-hangzhou.aliyuncs.com/spider_tie/rabbitmq:3.7
    restart: always
    ulimits:
      nofile:
        soft: 65536
        hard: 65536
    environment:
      - TZ=Asia/Shanghai
      - RABBITMQ_DEFAULT_USER=rbadmin
      - RABBITMQ_DEFAULT_PASS=OpsXlab2024!i
    volumes:
      - ./data:/var/lib/rabbitmq
    networks:
      - app-tier
        #ipv4_address: 172.22.1.10
    ports:
      - 5672:5672
      - 15672:15672
networks:
  app-tier:
    name: app-tier
    driver: bridge
    #external: true
    # ipam:
    #  config:
    #    - subnet: 172.22.1.0/24
bash 复制代码
docker-compose up -d

web端查看服务如下,mq中没有队列消息

可以看到队列无消息,但是原来的mq服务是有消息的

2.解决消息未显示问题

需要备份hostname和cookie,要不然持久化消息无法被识别

bash 复制代码
docker exec -it f43fb7de1ba1 cat /var/lib/rabbitmq/.erlang.cookie
docker exec -it f43fb7de1ba1 hostname

例如在101上操作

bash 复制代码
[root@centos-1 mnesia]# docker exec -it f43fb7de1ba1 cat /var/lib/rabbitmq/.erlang.cookie
IHMICEQVPBXTPPFDNFTT
[root@centos-1 mnesia]# docker exec -it f43fb7de1ba1 hostname
f43fb7de1ba1

然后再备用服务器103操作

bash 复制代码
(base) [root@centos-3 rabbitmq]# docker exec -it a0dbe129970f cat /var/lib/rabbitmq/.erlang.cookie
IHMICEQVPBXTPPFDNFTT
(base) [root@centos-3 rabbitmq]# docker exec -it a0dbe129970f hostname
a0dbe129970f

docker-compose.yml文件如下

bash 复制代码
services:
  rabbitmq:
    container_name: rabbitmq
    image: registry.cn-hangzhou.aliyuncs.com/spider_tie/rabbitmq:3.7
    restart: always
    hostname: f43fb7de1ba1
    ulimits:
      nofile:
        soft: 65536
        hard: 65536
    environment:
      - TZ=Asia/Shanghai
      - RABBITMQ_DEFAULT_USER=rbadmin
      - RABBITMQ_DEFAULT_PASS=OpsXlab2024!i
      - RABBITMQ_ERLANG_COOKIE=IHMICEQVPBXTPPFDNFTT
    volumes:
      - ./data:/var/lib/rabbitmq
    networks:
      - app-tier
        #ipv4_address: 172.22.1.10
    ports:
      - 5672:5672
      - 15672:15672
networks:
  app-tier:
    name: app-tier
    driver: bridge
    #external: true
    # ipam:
    #  config:
    #    - subnet: 172.22.1.0/24

注:主要是新增hostname,RABBITMQ_ERLANG_COOKIE

修改之后重新启动查看效果

备份前

备份后

至此,问题解决

相关推荐
China_Yanhy24 分钟前
入职 Web3 运维日记 · 第 8 日:黑暗森林 —— 对抗 MEV 机器人的“三明治攻击”
运维·机器人·web3
艾莉丝努力练剑30 分钟前
hixl vs NCCL:昇腾生态通信库的独特优势分析
运维·c++·人工智能·cann
酉鬼女又兒38 分钟前
每天一个Linux命令_printf
linux·运维·服务器
翼龙云_cloud39 分钟前
国际云代理商:2026年国际云注册风控升级实战指南 8 大平台无卡解决方案对比
服务器·阿里云·云计算
虾说羊43 分钟前
docker容器化部署项目流程
运维·docker·容器
Trouvaille ~44 分钟前
TCP Socket编程实战(三):线程池优化与TCP编程最佳实践
linux·运维·服务器·网络·c++·网络协议·tcp/ip
大大大反派1 小时前
CANN 生态中的自动化部署引擎:深入 `mindx-sdk` 项目构建端到端 AI 应用
运维·人工智能·自动化
June`1 小时前
高并发网络框架:Reactor模式深度解析
linux·服务器·c++
WHD3061 小时前
苏州勒索病毒加密 服务器数据解密恢复
运维·服务器
蜡笔小炘2 小时前
LVS -- 持久链接(Persistent Connection)实现会话粘滞
运维·服务器