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

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

备份前

备份后

至此,问题解决

相关推荐
哲讯智能科技8 小时前
苏州SAP代理商:哲讯科技助力企业数字化转型
大数据·运维·人工智能
十五年专注C++开发8 小时前
Qt .pro配置gcc相关命令(三):-W1、-L、-rpath和-rpath-link
linux·运维·c++·qt·cmake·跨平台编译
摸鱼仙人~8 小时前
如何设计一个既提供绘图Tools又提供example_data的MCP服务器:
android·服务器·javascript
qq_628515768 小时前
Centos与RockLinux设置静态ip
linux·运维·centos
程序员老乔8 小时前
【Dify系列】【一】【安装与部署】【ubuntu22.04安装docker部署dify1.4.2】
运维·docker·容器
沧浪之水120101379 小时前
linux常用命令
linux·运维·服务器
梦会实现9 小时前
无外接物理显示器的Ubuntu系统的远程桌面连接(升级版)
linux·运维·ubuntu·计算机外设
Hello.Reader9 小时前
NGINX 四层共享内存区同步模块实战 `ngx_stream_zone_sync_module`
运维·nginx
暗离子跃迁10 小时前
达梦数据库单机部署dmhs同步复制(dm8->kafka)
linux·运维·数据库·分布式·学习·kafka·达梦数据库
北城笑笑10 小时前
Server 11 ,⭐通过脚本在全新 Ubuntu 系统中安装 Nginx 环境,安装到指定目录( 脚本安装Nginx )
linux·运维·前端·nginx·ubuntu