当前位置: 首页 > news >正文

RabbitMQ:延时消息(死信交换机、延迟消息插件)

目录

  • 一、死信交换机【不推荐】
  • 二、延迟消息插件【推荐】
    • 2.1 安装插件【Linux】
    • 2.2 安装插件【Windows】
    • 2.3 如何使用


延时消息:生产者发送消息时指定一个时间,消费者不会立刻收到消息,而是在指定时间之后才收到消息。
延时任务:设置一定时间之后才执行的任务。

一、死信交换机【不推荐】

当一个队列的消息满足下列情况之一时,就会成为死信(dead letter):

  • 消费者使用basic.reject或basic.nack声明消费失败,并且消息的requeue参数设置为false。
  • 消息是一个过期消息(达到了队列或消息本身设置的过期时间),超时无人消费。
  • 要投递的队列消息堆积满了,最早的消息可能成为死信。

如果队列通过dead-letter-exchange属性指定了一个交换机,那么该队列中的死信就会投递到这个交换机中。这个交换机也称之为死信交换机

在这里插入图片描述
具体实现流程如下:

  1. 首先创建两个队列direct.queue、dlx.queue,需要注意的是在创建direct.queue队列时,需要绑定死信交换机。

在这里插入图片描述
如何绑定死信交换机:选中Dead letter exchange输入交换机的名称
在这里插入图片描述
2. 创建两个交换机分别绑定两个队列mt.direct、mt.dlx.direct

在这里插入图片描述
3. 消费者监听死信队列,并给mt.direct发送定时消息

@Test
public void dlxExchangeTest(){String exchangeName = "mt.direct";String message = "黄色警报 ......";rabbitTemplate.convertAndSend(exchangeName, "dlx", message, new MessagePostProcessor() {@Overridepublic Message postProcessMessage(Message message) throws AmqpException {message.getMessageProperties().setExpiration("1000");  // 设置过期时间,单位ms,1000=1sreturn message;}});
}
@RabbitListener(queues = "dlx.queue")
public void listenDlxQueue(String message){System.out.println(String.format("消费者收到了dlx.queue: %s", message));
}

二、延迟消息插件【推荐】

要想使用延迟消息,需要先安装延迟消息插件rabbitmq_delayed_message_exchange,根据自己RabbitMQ的版本去下载。

2.1 安装插件【Linux】

去官网下载插件。
在这里插入图片描述
将插件放入RabbitMQ的plugins中,具体路径如下:

/usr/lib/rabbitmq/lib/rabbitmq_server-3.13.7/plugins

安装插件

rabbitmq-plugins enable rabbitmq_delayed_message_exchange

重启RabbitMQ服务

systemctl restart rabbitmq-server

再次登录rabbitmq,如果exchange的类型中出现:x-delayed-message,说明该插件安装成功!
在这里插入图片描述

2.2 安装插件【Windows】

将插件放入RabbitMQ的plugins中,具体路径如下:

xxx\RabbitMQ Server\rabbitmq_server-3.12.10\plugins

然后进入到RabbitMQ额度sbin目录下,执行以下命令:

rabbitmq-plugins enable rabbitmq_delayed_message_exchange

2.3 如何使用

rabbitmq_delayed_message_exchange插件的实现原理是设计了一种支持延迟消息功能的交换机,当消息投递到交换机后可以暂存一段时间,到期后在投递到队列。

Java注解的实现方式

@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "delay.queue", durable = "true"),exchange = @Exchange(name = "mt.delay.direct", delayed = "true"),key = "delay"
))
public void listenDelayQueue(String message){System.out.println(String.format("消费者收到了delay.queue: %s", message));
}

Java Bean的实现方式

@Bean
public DirectExchange delayExchange() {return ExchangeBuilder.directExchange("mt.delay.direct").durable(true).delayed().build();
}

消费者

@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "delay.queue", durable = "true"),exchange = @Exchange(name = "mt.delay.direct", delayed = "true"),key = "delay"
))
public void listenDelayQueue(String message){System.out.println(String.format("消费者收到了delay.queue: %s", message));
}

生产者

@Test
public void delayExchangeTest(){String exchangeName = "mt.delay.direct";String message = "延迟警报 ......";rabbitTemplate.convertAndSend(exchangeName, "delay", message, new DelayMessageProcessor(5000));
}
package com.ming.processor;import lombok.RequiredArgsConstructor;
import org.springframework.amqp.AmqpException;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.core.MessagePostProcessor;/*** @RequiredArgsConstructor 是Lombok库提供的一个注解,用于自动生成包含必需参数的构造函数。必需参数是指那些被声明为 final 或者有 @NonNull 注解的成员变量。*/
@RequiredArgsConstructor
public class DelayMessageProcessor implements MessagePostProcessor {/*** 定义延迟时间*/private final int delay;@Overridepublic Message postProcessMessage(Message message) throws AmqpException {message.getMessageProperties().setDelay(delay);return message;}
}
http://www.xdnf.cn/news/1337455.html

相关文章:

  • 深入理解Docker网络:从docker0到自定义网络
  • Python核心技术开发指南(001)——Python简介
  • NPM组件 @angular_devkit/core 等窃取主机敏感信息
  • uniapp vue3 ts自定义底部 tabbar菜单
  • AUTOSAR自适应平台(AP)中元类(Metaclass)、建模(Modeling) 和 ARXML 这三者的核心关系与区别
  • AR眼镜在制造业的生产设备智慧运维方案介绍
  • Multi Agents Collaboration OS:Browser Automation System
  • 自动驾驶GOD:3D空间感知革命
  • C++析构函数
  • 训练后数据集后部署PaddleOCR转trt流程
  • 使用C++17标准 手写一个vector
  • [Mysql数据库] Mysql安全知识
  • 12KM无人机高清图传通信模组——打造未来空中通信新高度
  • Docker操作速查表
  • 动态规划----6.单词拆分
  • AI重塑软件测试:质量保障的下一站
  • 【clion】cmake脚本1:调试脚本并构建Fargo项目win32版本
  • Linux: network: arp: arp_accept
  • HTML应用指南:利用POST请求获取全国刘文祥麻辣烫门店位置信息
  • 我从零开始学习C语言(12)- 循环语句 PART1
  • DRF序列化器
  • PyTorch API 7
  • 数据安全事件分级
  • 嵌入式的各个要点总结(不断更新)
  • KubeBlocks for ClickHouse 容器化之路
  • 第三十三天(信号量)
  • GO环境变量中GO111MODULE到底是干啥的?
  • 【NFTurbo】基于Redisson滑动窗口实现验证码发送限流
  • 【运维】githubvercel学习使用
  • nginx-下载功能-状态统计-访问控制