广告
返回顶部
首页 > 资讯 > 精选 >RabbitMQ中死信队列和延迟队列如何使用
  • 331
分享到

RabbitMQ中死信队列和延迟队列如何使用

2023-06-30 16:06:01 331人浏览 薄情痞子
摘要

这篇文章主要讲解了“RabbitMQ中死信队列和延迟队列如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“RabbitMQ中死信队列和延迟队列如何使用”吧!死信队列简介DLX,全称为De

这篇文章主要讲解了“RabbitMQ中死信队列和延迟队列如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“RabbitMQ中死信队列和延迟队列如何使用”吧!

死信队列

简介

DLX,全称为Dead-Letter-Exchange,可以称之为死信交换器,也有人称之为死信邮箱。当消息在一个队列中变成死信(dead message)之后,它能被重新被发送到另一个交换器中,这个交换器就是DLX,绑定DLX的队列就称之为死信队列。

以下几种情况会导致消息变成死信:

  • 消息被拒绝(Basic.Reject/Basic.Nack),并且设置requeue参数为false;

  • 消息过期;

  • 队列达到最大长度。

DLX是一个正常的交换器,和一般的交换器没有区别,它能在任何的队列上被指定,实际上就是设置某个队列的属性。当这个队列中存在死信时,RabbitMQ就会自动地将这个消息重新发布到设置的DLX上去,进而被路由到另一个队列,即死信队列。可以监听这个队列中的消息以进行相应的处理,这个特性与将消息的TTL设置为0配合使用可以弥补immediate参数的功能。

为队列添加DLX的方法

法1:代码方式

//创建 DLX: dlx_exchangechannel.exchangeDeclare("dlx_exchange", "direct" );Map<String, Object> args = new HashMap<String, Object>;args.put("x-dead-letter-exchange", "dlx_exchange");//为队列myqueue添加DLXchannel.queueDeclare("myqueue", false, false, false, args);

也可以为这个DLX指定路由键。(如果没有特殊指定,则使用原队列的路由键)

args.put("x-dead-letter-routing-key","dlx-routing-key");

法2:命令方式

rabbitmqctl set_policy DLX ".*" '{"dead-letter-exchange":"dlx_exchange"}' --apply-to queues

示例

代码

channel.exchangeDeclare("exchange.dlx", "direct", true);channel.exchangeDeclare("exchange.nORMal", "fanout", true);Map<String, Object> args = new HashMap<String, Object>();args.put("x-message-ttl", 10000);args.put("x-dead-letter-exchange" , "exchange.dlx");args.put("x-dead-letter-routing-key" , "routingkey");channel.queueDeclare("queue.normal" , true, false, false, args);channel.queueBind("queue.normal", "exchange.normal", "");channel.queueDeclare("queue.dlx", true, false, false, null);channel.queueBind("queue.dlx", "exchange.dlx" , "routingkey");channel.basicPublish("exchange.normal" , "rk",MessageProperties.PERSISTENT_TEXT_PLaiN, "dlx".getBytes());

这里创建了两个交换器exchange.normal和exchange.dlx,分别绑定两个队列queue.normal和queue.dlx。

Web管理页面结果

由下图(图1-1)的WEB管理页面可以看出,两个队列都被标记了“D”,这个是durable的缩写,即设置了队列持久化。queue.normal这个队列还配置了TTL、DLX和DLK,其中DLX指的是
x-dead-letter-routing-key这个属性。 

RabbitMQ中死信队列和延迟队列如何使用

图1-1

案例分析

参考下图(图1-2),生产者首先发送一条携带路由键为“rk”的消息,然后经过交换器exchange.normal顺利地存储到队列queue.normal中。由于队列queue.normal设置了过期时间为10s,在这10s内没有消费者消费这条消息,那么判定这条消息为过期。由于设置了DLX,过期之时,消息被丢给交换器exchange.dlx中,这时找到与exchange.dlx匹配的队列queue.dlx,最后消息被存储在queue.dk这个死信队列中。 

RabbitMQ中死信队列和延迟队列如何使用

图1-2

对于RabbitMQ来说,DLX是一个非常有用的特性。它可以处理异常情况下,消息不能够被消费者正确消费(消费者调用了Basic.Nack或者Basic.Reject)而被置入死信队列中的情况,后续分析程序可以通过消费这个死信队列中的内容来分析当时所遇到的异常情况,进而可以改善和优化系统。DLX配合TTL使用还可以实现延迟队列的功能,详细请看下一节。

延迟队列

简介

延迟队列用来存放延迟消息。延迟消息:指当消息被发送以后,不想让消费者立刻拿到消息,而是等待特定时间后,消费者才能拿到这个消息进行消费。

在AMQP协议中,或者RabbitMQ本身没有直接支持延迟队列的功能,但是有两种方案来间接实现:

  • 方案1:采用rabbitmq-delayed-message-exchange 插件实现。(RabbitMQ 3.6.x开始支持)

  • 方案2:通过前面所介绍的DLX和TTL模拟出延迟队列的功能。

在图1-2中,不仅展示的是死信队列的用法,也是延迟队列的用法,对于queue.dlx这个死信队列来说,同样可以看作延迟队列。假设一个应用中需要将每条消息都设置为10秒的延迟,

生产者通过exchange.normal这个交换器将发送的消息存储在queue.normal这个队列中。消费者订阅的并非是queue.normal这个队列,而是queue.dlx这个队列。当消息从queue.normal这个队列中过期之后被存入queue.dlx这个队列中,消费者就恰巧消费到了延迟10秒的这条消息。

在真实应用中,对于延迟队列可以根据延迟时间的长短分为多个等级,一般分为5秒、10秒、30秒、1分钟、5分钟、10分钟、30分钟、1小时这几个维度,当然也可以再细化一下。

以下图(图2-1)为例进行说明。为简化,只设置5秒、10秒、30秒、1分钟这四个等级。根据需求的不同,生产者发送消息的时候通过设置不同的路由键,将消息发送到与交换器绑定的不同的队列中。这里队列也分别配置了DLX和相应的死信队列,当相应的消息过期时,就会转存到相应的死信队列(即延迟队列)中,这样消费者根据业务自身的情况,分别选择不同延迟等级的延迟队列进行消费。

RabbitMQ中死信队列和延迟队列如何使用

图2-1

使用场景

延迟队列的使用场景有很多,比如:

用户下订单场景:用户下单后有30分钟的时间支付,若30分钟内没有支付,则将这个订单取消。

方案:用户下单后将取消订单的消息发送到延迟队列,延迟时间设置为30分钟。取消订单这个消息的订阅者程序在30分钟后收到消息,判断该订单的状态是否为已支付,若还没支付,则将该订单状态设置为:已取消。

定时遥控场景:用户想用手机远程遥控家里的智能设备在指定的时间工作。

方案:假设用户想要的操作是:开启热水器。首先,将开启热水器这个消息发送到延迟队列,延迟时间设置到用户想要的时间到现在时间的差值。开启热水器这个消息的订阅者程序在指定时间收到消息,再将指令推送到智能设备。

需要注意的是,延迟队列的消息是不能取消的,解决方案是:在消费消息的时候判断这个消息对应的业务的当前状态。例如:对于取消订单来说,收到消息时,读取这个消息所对应的数据库信息,如果已经是已付款状态了,就不进行任何操作了,如果是未支付状态,则改为已取消。

感谢各位的阅读,以上就是“RabbitMQ中死信队列和延迟队列如何使用”的内容了,经过本文的学习后,相信大家对RabbitMQ中死信队列和延迟队列如何使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: RabbitMQ中死信队列和延迟队列如何使用

本文链接: https://www.lsjlt.com/news/330354.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • RabbitMQ中死信队列和延迟队列如何使用
    这篇文章主要讲解了“RabbitMQ中死信队列和延迟队列如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“RabbitMQ中死信队列和延迟队列如何使用”吧!死信队列简介DLX,全称为De...
    99+
    2023-06-30
  • SpringBoot整合RabbitMQ处理死信队列和延迟队列
    目录简介实例代码路由配置控制器发送器接收器application.yml实例测试简介 说明 本文用示例介绍SpringBoot整合RabbitMQ时如何处理死信队列/延迟队列。 Ra...
    99+
    2022-11-13
  • 详解RabbitMQ中死信队列和延迟队列的使用详解
    目录简介死信队列简介示例延迟队列简介使用场景简介 本文介绍RabbitMQ的死信队列和延迟队列。 本内容也是Java后端面试中常见的问题。 死信队列 简介 DLX,全称为Dead-L...
    99+
    2022-11-13
  • SpringBoot怎么整合RabbitMQ处理死信队列和延迟队列
    今天小编给大家分享一下SpringBoot怎么整合RabbitMQ处理死信队列和延迟队列的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了...
    99+
    2023-06-30
  • 队列的死信队列和延迟队列在PHP与MySQL中的应用场景
    引言随着互联网应用变得越来越复杂,处理大量消息和任务的需求日益增长。队列作为一种解决方案,能够有效地实现任务的异步处理,提高系统的可伸缩性和稳定性。在队列的应用中,常见的两个概念是死信队列和延迟队列。本文将介绍这两个概念在PHP与MySQL...
    99+
    2023-10-21
    队列 (Queue) 死信队列 (Dead Letter Queue) 延迟队列 (Delay Queue)
  • RabbitMQ死信机制实现延迟队列的实战
    目录延迟队列应用场景TimeToLive(TTL) DeadLetterExchanges(DLX)延迟队列 延迟队列存储的对象肯定是对应的延时消息,所谓”延时消息”是指当...
    99+
    2022-11-12
  • 运用.NetCore实例讲解RabbitMQ死信队列,延时队列
    目录一、死信队列二、延时队列三、延时消息设置不同过期时间四、延时消息用延时插件的方式实现一、死信队列 描述:Q1队列绑定了x-dead-letter-exchange(死信交换机)...
    99+
    2022-11-12
  • springcloud中RabbitMQ死信队列与延迟交换机实现方法
    目录0.引言1. 死信队列1.2 什么是死信?1.3 什么是死信队列?1.4 创建死信交换机、死信队列1.5 实现死信消息1.5.1 基于消费者进行reject或nack实现死信消息...
    99+
    2022-11-13
  • 详解RabbitMQ延迟队列的基本使用和优化
    目录1.延迟队列基本介绍2.延迟队列使用场景3.Spring Boot集成RabbitMQ3.1创建项目,引入依赖3.2application.properties配置文件3.3 队...
    99+
    2023-05-19
    RabbitMQ 延迟队列 RabbitMQ 队列
  • 如何利用rabbitMq的死信队列实现延时消息
    目录前言mq基本的消息模型mq死信队列的消息模型maven依赖配置普通队列和死信队列死信队列消费者发送消息测试测试成功总结前言 使用mq自带的死信去实现延时消息要注意一个坑点,就是m...
    99+
    2023-01-28
    rabbitMq死信队列 rabbitMq延时消息 rabbitMq延时队列
  • 如何在Java中使用延迟队列
    本篇文章给大家分享的是有关如何在Java中使用延迟队列,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。  DelayQueue首先,定义一个延迟任务package&nb...
    99+
    2023-06-14
  • .NETCore中RabbitMQ使用死信队列的实现
    在.NET Core中,可以使用RabbitMQ.Client库来实现与RabbitMQ的交互。 RabbitMQ死信队列(Dead Letter Queue)是一种用于存储和处理无...
    99+
    2023-05-14
    .NET Core RabbitMQ死信队列 .NET Core 死信队列
  • thinkphp6、thinkphp5.0 使用think-queue实现普通队列和延迟队列
    何为异步消息队列: 所谓消息队列,就是一个以队列数据结构为基础的一个实体,这个实体是真实存在的,比如程序中的数组,数据库中的表,或者redis等等,都可以。 异步队列的作用: 个人认为消息队列的主...
    99+
    2023-08-31
    redis php
  • .NET Core中RabbitMQ使用死信队列如何实现
    本篇内容介绍了“.NET Core中RabbitMQ使用死信队列如何实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在.NET ...
    99+
    2023-07-05
  • Java线程池队列中的延迟队列DelayQueue怎么使用
    今天小编给大家分享一下Java线程池队列中的延迟队列DelayQueue怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧...
    99+
    2023-07-04
  • thinkphp6使用think-queue怎么实现普通队列和延迟队列
    本文小编为大家详细介绍“thinkphp6使用think-queue怎么实现普通队列和延迟队列”,内容详细,步骤清晰,细节处理妥当,希望这篇“thinkphp6使用think-queue怎么实现普通队列和延迟队列”文章能帮助大家解决疑惑,下...
    99+
    2023-06-30
  • Redis中如何实现消息队列和延时消息队列
    这篇文章将为大家详细讲解有关Redis中如何实现消息队列和延时消息队列,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。list的几个命令lpush (left push)由...
    99+
    2022-10-19
  • RabbitMQ延迟队列如何实现订单支付结果异步阶梯性通知
    小编给大家分享一下RabbitMQ延迟队列如何实现订单支付结果异步阶梯性通知,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!在第三方支付中,例如支付宝、或者微信,对于订单请求,第三方支付系统采用的是消息同步返回、异步通知+主...
    99+
    2023-06-29
  • Springboot死信队列 DLX 配置和使用思路分析
    目录前言什么是死信配置和测试死信思路分析配置类编写编写消息发送服务测试消息什么时候会成为死信消息?总结参考资料代码下载前言 上一篇博客 Springboot—&mdash...
    99+
    2022-11-13
  • 队列的延迟任务和定时任务在PHP与MySQL中的应用场景
    引言:随着互联网的发展,对于实时性和高并发的需求越来越高,为了应对这些需求,我们常常需要使用到队列的延迟任务和定时任务。本文将重点介绍在PHP和MySQL中,如何应用队列的延迟任务和定时任务,并给出具体的代码示例。一、队列的延迟任务的应用场...
    99+
    2023-10-21
    MySQL PHP 队列 定时任务 延迟任务
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作