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

RabbitMQ(高阶使用)死信队列

文章内容是学习过程中的知识总结,如有纰漏,欢迎指正

文章目录

一、什么是死信队列?

二、死信队列使用场景

三、死信队列如何使用

四、打车超时处理

 1.打车超时实现


以下是本篇文章正文内容

一、什么是死信队列?

        先从概念解释上搞清楚这个定义,死信,顾名思义就是无法被消费的消息,字面意思可以这样理解

        一般来说,producer将消息投递到broker或者直接到queue里了,consumer从queue取出消息进行消费,但某些时候由于特定的原因导致queue中的某些消息无法被消费,这样的消息如果没有后续的处理,就变成了死信,有死信,自然就有了死信队列;

二、死信队列使用场景

RabbitMQ中的死信交换器(dead letter exchange)可以接收下面三种场景中的消息:

  • 消费者对消息使用了basicReject或者basicNack回复,并且requeue参数设置为false,即不再将该消息重新在消费者间进行投递
  • 消息在队列中超时,RabbitMQ可以在单个消息或者队列中设置TTL(最大存活时间)属性
  • 队列中的消息已经超过其设置的最大消息个数

三、死信队列如何使用

        死信交换器不是默认的设置,这里是被投递消息被拒绝后的一个可选行为,是在创建队列的时进行声明的,往往用在对问题消息的诊断上。

        死信交换器仍然只是一个普通的交换器,创建时并没有特别要求和操作,在创建队列的时候,声明该交换器将用作保存被拒绝的消息即可,相关的参数是x-dead-letter-exchange。     

   相关代码

@Bean
public Queue taxiOverQueue() {Map<String, Object> args = new HashMap<>(2);// x-dead-letter-exchange    这里声明当前队列绑定的死信交换机args.put("x-dead-letter-exchange", TAXI_DEAD_QUEUE_EXCHANGE);// x-dead-letter-routing-key  这里声明当前队列的死信路由keyargs.put("x-dead-letter-routing-key", TAXI_DEAD_KEY);return QueueBuilder.durable(TAXI_OVER_QUEUE).withArguments(args).build();
}

四、打车超时处理

        用户通过调用打车服务将数据放进RabbitMQ的死信队列进行延时操作,等待一段时间后,正常的业务处理还没有处理到我们发起的数据,将会进行超时处理,通过通知服务将我们的处理结构通过websocket方式推送到我们的客户端。

 1.打车超时实现

        在创建队列的时候配置死信交换器并设置队列的“x-message-ttl”属性。此时该属性为整个队列消息的生存时间,这里有一篇专门讲延时任务的文章。RabbitMQ(高阶使用)延时任务-CSDN博客

@Bean
public Queue taxiDeadQueue() {return new Queue(TAXI_DEAD_QUEUE,true);
}@Bean
public Queue taxiOverQueue() {Map<String, Object> args = new HashMap<>(2);// x-dead-letter-exchange    这里声明当前队列绑定的死信交换机args.put("x-dead-letter-exchange", TAXI_DEAD_QUEUE_EXCHANGE);// x-dead-letter-routing-key  这里声明当前队列的死信路由keyargs.put("x-dead-letter-routing-key", TAXI_DEAD_KEY);// x-message-ttl  声明队列的TTLargs.put("x-message-ttl", 30000);return QueueBuilder.durable(TAXI_OVER_QUEUE).withArguments(args).build();
}

这样所有被投递到该队列的消息都最多不会存活超过30s,超时后的消息会被投递到死信交换器

http://www.lryc.cn/news/439796.html

相关文章:

  • 怎么安装docker-compose
  • 【机器学习】--- 自监督学习
  • 【Linux修行路】网络套接字编程——UDP
  • 哈希表数据结构学习
  • 数据结构——“二叉搜索树”
  • Java零基础-Java对象详解
  • 从Prompt到创造:解锁AI的无限潜能
  • sqlgun靶场攻略
  • 《网络协议 - HTTP传输协议及状态码解析》
  • 9.11 QT ( Day 4)
  • 利用AI驱动智能BI数据可视化-深度评测Amazon Quicksight(四)
  • 2024.9最新:CUDA安装,pytorch库安装
  • Vue3.0组合式API:setup()函数
  • 利用AI驱动智能BI数据可视化-深度评测Amazon Quicksight(三)
  • 2022高教社杯全国大学生数学建模竞赛C题 问题一(1) Python代码演示
  • Qt QSerialPort数据发送和接收DataComm
  • macOS上谷歌浏览器的十大隐藏功能
  • 【C++篇】C++类与对象深度解析(二):类的默认成员函数详解
  • Linux2-mkdir,touch,cat,more
  • AI 时代程序员的应变之道
  • SQL编程题复习(24/9/16)
  • 运维工程师面试整理-操作系统
  • Linux搭建邮箱服务器(简易版)
  • 基于SSM的社区爱心捐赠管理系统
  • 鸿蒙next web组件和h5 交互实战来了
  • 甘特图介绍
  • 第十一章 【后端】商品分类管理微服务(11.1)——创建父工程
  • c语言中的“二级指针”与“指针数组”
  • IDA f5 无法生成伪代码 too big function 的原因之一以及解决方法
  • OpenCV-上下采样