RabbitMQ的延迟队列实现[死信队列](笔记一)

关于死信队列的使用场景不再强调,只针对服务端配置
注意: 本文只针对实现死信队列的rabbitMQ基本配置步骤进行阐述和实现

目录

1、docker-compose 安装rabbitMq

a、使用docker-compose.yml安装rabbitMq,配置如下

yml 复制代码
version: '3.1'
services:
  rabbitmq:
    image: rabbitmq:3.8.3-management
    container_name: rabbitmq
    restart: always
    hostname: myRabbitmq
    ports:
      - 15673:15672
      - 5673:5672
      - 15674:15674
    volumes:
      - /opt/rabbitmq/data:/var/lib/rabbitmq
    environment:
      - RABBITMQ_DEFAULT_USER=root
      - RABBITMQ_DEFAULT_PASS=root+12345678

注意: 建议大家安装带有-management的,可进行控制台登录查看

b、启动

shell 复制代码
docker-compose up -d rabbitmq

c、查看状态,如下图

shell 复制代码
docker ps

d、访问(ip+端口)并登录

1.2.3.4:15673

2、查看对应的版本及插件下载

a、从docker-compose 可以看到本版为3.8.3,所以下载对应版本或者大版本相同的延迟插件

b、下载链接: https://www.rabbitmq.com/community-plugins.html

c、在该地址页面找:rabbitmq_delayed_message_exchange

d、我这里下载了rabbitmq_delayed_message_exchange-3.8.0.ez

e、将文件上传至rabbitMQ所在服务器即可

3、安装插件和检测

a、先确认RabbitMQ服务是否安装过死信队列组件(两种方式)

第一种、控制台------>Exchanges------>Add a new exchange,查看Type下拉框,没有x-delayed-message

第二种、服务端进入容器查看

shell 复制代码
//TODO 进入容器
docker exec -it rabbitmq bash
//TODO 进入插件目录
cd plugins
//TODO 查看插件列表
ls

b、安装

1、使用 docker 命令将上传好的插件复制到容器内部 插件目录下

shell 复制代码
docker cp rabbitmq_delayed_message_exchange-3.8.0.ez  rabbitmq:/plugins

2、进入容器查看是否复制成功

shell 复制代码
 //TODO 进入容器
docker exec -it rabbitmq bash
//TODO 进入插件目录
cd plugins
//TODO 查看插件列表
ls

3、安装启用

shell 复制代码
 //执行启用插件命令
rabbitmq-plugins enable rabbitmq_delayed_message_exchange
shell 复制代码
 //查看结果,并退出容器
rabbitmq-plugins enable rabbitmq_delayed_message_exchange
//退出容器
exit

c、重启RabbitMq服务

shell 复制代码
docker restart rabbitmq

d、检查对比

1.登录台控制台------>Exchanges------>Add a new exchange,查看Type下拉框,已经有了x-delayed-message

相关推荐
普通网友2 小时前
《K8s 自动扩缩容:基于 CPU / 内存的 HPA 配置》
docker·容器·kubernetes
少许极端4 小时前
消息队列5-RabbitMQ的高级特性和MQ的应用问题与解决方案-事务、消息分发的应用、幂等性保证、顺序性保证、消息积压的解决
分布式·消息队列·rabbitmq
Arva .6 小时前
RabbitMQ
网络·分布式·rabbitmq
zfoo-framework8 小时前
docker compose安装gitea实现公司内部开发git私有仓库
docker·容器·gitea
无巧不成书02189 小时前
基于WSL 2的Docker远程开发全栈实战指南
运维·docker·容器·docker desktop·wsl 2·vs code远程开发·容器化开发
Renhao-Wan9 小时前
Docker 核心原理详解:镜像、容器、Namespace、Cgroups 与 UnionFS
java·后端·docker·容器
赵庆明老师9 小时前
Linux Docker打包
linux·运维·docker
Eloudy9 小时前
docker pull ubuntu:22.04 失败的解决记录
运维·docker·容器
小江的记录本9 小时前
【RabbitMQ】RabbitMQ核心知识体系全解(5大核心模块:Exchange类型、消息确认机制、死信队列、延迟队列、镜像队列)
java·前端·分布式·后端·spring·rabbitmq·mvc
taWSw5OjU10 小时前
Docker] Docker中`overlay2`磁盘占用爆满的清理方案
docker·容器·eureka