RabbitMQ 消息队列 延时队列和死信队列
如果你不熟悉RabbitMQ,本文从图形界面入手介绍 RabbitMQ 的基本使用方法和 延时队列和死信队列的实现方法。
如果需要代码实现的话请参考:[java 代码](gitee.com/xuejianxino…
1. windows 上安装rabbitmq
- 安装 erlang 虚拟机 otp_win64_23.2.exe
- 安装 rabbitmq-server-3.8.14.exe
安装完成后 ,启动类型最好 修改为手动
- 打开rabbitmq 控制台 参考文档 blog.csdn.net/chentao866/…
打开rabbitMQ的控制台输入:启用管理插件
rabbitmq-plugins enable rabbitmq_management
在浏览器中 打开 http://127.0.0.1:15672/
超级管理员账号和密码都是:guest
2. fanout 模式
Exchange和Queue建立一个绑定关系,Exchange会分发给所有和它有绑定关系的Queue中,绑定了十个Queue就把消息复制十份进行分发。
创建2个用于接收fanout 消息的队列
创建交换机
创建绑定关系
最终的绑定关系
然后在 队列查看是否收到消息
查看消息
可以看到消息具体内容
3. Direct-Exchange 模式
准备一条消息发往名为SendService的直接交换机中去,这个交换机主要是用来做发送服务,所以其绑定了两个队列,SMS队列和MAIL队列,用于发送短信和邮件。 我们的消息除了指定ExchangeKey(此处为SendService)还需要指定routingKey(具体到那个队列 sms还是mail ),routingKey对应着最终要发送的是哪个队列,我们的示例中的routingKey是sms,这里这条消息就会交给SMS队列
创建队列 mailQueue和smsQueue
创建交换机
设置与队列的绑定关系
发送sms 消息
发送mail 消息
测试消费消息同fanout
4.Topic-Exchange
' *:能够模糊匹配一个单词。
' #:能够模糊匹配零个或多个单词。
因为加入了两个通配定义符,所以Topic交换机的routingKey也有些变化,routingKey可以使用 . 将单词分开。
创建交换机
5.实现延迟消息
www.rabbitmq.com/community-p… 版本太旧不能用,不能支持到3.8.14
www.rabbitmq.com/priority.ht… 支持优先队列
Channel ch = ...;
Map<String, Object> args = new HashMap<String, Object>(); args.put("x-max-priority", 10); ch.queueDeclare("my-priority-queue", true, false, false, args); 利用单独延迟队列 实现消息过时 创建一个延迟队列 延迟10s
单独设置消息ttl,使条消息过时 添加一个普通队列 testQueue
6.死信队列
作者:xuejianxinokok
链接:https://juejin.cn/post/7095299294629986340
来源:稀土掘金