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

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

备份前

备份后

至此,问题解决

相关推荐
爱吃橘子橙子柚子3 天前
3CPU性能排查总结(超详细)【Linux性能优化】
运维·cpu
舒一笑5 天前
程序员效率神器:一文掌握 tmux(服务器开发必备工具)
运维·后端·程序员
NineData5 天前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
梦想很大很大6 天前
拒绝“盲猜式”调优:在 Go Gin 项目中落地 OpenTelemetry 链路追踪
运维·后端·go
Sinclair6 天前
内网服务器离线安装 Nginx+PHP+MySQL 的方法
运维
叶落阁主6 天前
Tailscale 完全指南:从入门到私有 DERP 部署
运维·安全·远程工作
茶杯梦轩6 天前
从零起步学习RabbitMQ || 第二章:RabbitMQ 深入理解概念 Producer、Consumer、Exchange、Queue 与企业实战案例
服务器·后端·消息队列
用户8307196840827 天前
Spring Boot 集成 RabbitMQ :8 个最佳实践,杜绝消息丢失与队列阻塞
spring boot·后端·rabbitmq
甲鱼9297 天前
MySQL 实战手记:日志管理与主从复制搭建全指南
运维
YuMiao8 天前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议