RabbitMQ-中死信交换机

在RabbitMQ中,死信交换机(DLX,Dead Letter Exchange)是一种用于处理无法正常消费的消息的机制。当消息在一个队列中变成死信(dead letter)之后,它可以被重新发布到另一个交换机,这个交换机就被称为死信交换机。消息变成死信的原因通常有以下几种情况:

  1. 消息被拒绝(Basic.Reject/Basic.Nack)并且设置为不重新入队列。
  2. 消息在队列中的存活时间(TTL)到期。
  3. 队列达到最大长度。

RabbitMQ延迟队列可以通过使用死信交换机和消息的TTL设置来实现。

设置死信交换机和延迟队列

以下是如何使用Java代码来设置死信交换机和延迟队列:

import com.rabbitmq.client.*;public class DLXExample {public static void main(String[] argv) throws Exception {ConnectionFactory factory = new ConnectionFactory();factory.setHost("localhost");Connection connection = factory.newConnection();Channel channel = connection.createChannel();String exchangeName = "dlx_exchange";String routingKey = "dlx_routing_key";String queueName = "dlx_queue";// 声明一个死信交换机channel.exchangeDeclare(exchangeName, BuiltinExchangeType.TOPIC, true);// 设置队列的死信交换机属性AMQP.Queue.DeclareOk queue = channel.queueDeclare(queueName, true, false, false, Map.of("x-dead-letter-exchange", exchangeName,"x-dead-letter-routing-key", routingKey));// 绑定队列到死信交换机channel.queueBind(queue.getQueue(), exchangeName, routingKey);// ...其他业务代码}
}

在上述代码中,通过x-dead-letter-exchangex-dead-letter-routing-key参数,我们将队列绑定到了一个死信交换机。当该队列中的消息变为死信时,它们会被发送到这个死信交换机,并根据路由键路由到相应的队列。

为了实现延迟队列的效果,可以设置消息的TTL(Time-To-Live),或者设置队列的TTL。当消息过期后,如果队列设置了死信交换机,消息就会被发送到死信交换机。

发布消息到延迟队列

发布带有TTL的消息到队列:

import com.rabbitmq.client.AMQP;
import com.rabbitmq.client.Channel;import java.util.HashMap;
import java.util.Map;public class DelayedMessagePublisher {public static void main(String[] argv) throws Exception {// ...建立连接和通道的代码String queueName = "delayed_queue";String dlxExchangeName = "dlx_exchange";String dlxRoutingKey = "dlx_routing_key";// 声明延迟队列,将消息过期后路由到死信交换机Map<String, Object> args = new HashMap<>();args.put("x-dead-letter-exchange", dlxExchangeName);args.put("x-dead-letter-routing-key", dlxRoutingKey);channel.queueDeclare(queueName, true, false, false, args);String message = "This is a delayed message";AMQP.BasicProperties.Builder builder = new AMQP.BasicProperties.Builder();// 设置消息的TTLint ttl = 10000; // 消息的存活时间,单位为毫秒builder.expiration(String.valueOf(ttl));AMQP.BasicProperties properties = builder.build();// 发布消息到延迟队列channel.basicPublish("", queueName, properties, message.getBytes());System.out.println("Sent message: " + message + " with TTL: " + ttl);// ...关闭连接等清理代码}
}

在这个例子中,我们设置了消息的TTL属性,并将其发布到了延迟队列。消息过期后,它会自动转发到绑定的死信交换机,然后进入相应的队列。

消费死信队列中的消息

消费来自死信交换机的消息和常规消息消费类似,但是通常这些消息需要特殊处理,因为它们可能代表了失败或者需要延迟处理的情况。

import com.rabbitmq.client.*;public class DLXConsumer {public static void main(String[] argv) throws Exception {// ...建立连接和通道的代码String dlxQueueName = "dlx_queue";// 启动消费者监听死信队列DeliverCallback deliverCallback = (consumerTag, delivery) -> {String message = new String(delivery.getBody(), "UTF-8");System.out.println("Received from DLX: " + message);// 确认消息channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);};channel.basicConsume(dlxQueueName, false, deliverCallback, consumerTag -> {});// ...其他业务代码}
}

结合源码

深入源码层面,可以查看RabbitMQ Java客户端库中与队列声明相关的Channel接口方法,比如queueDeclarequeueBind。查看它们如何处理参数,尤其是那些以x-开头的参数,它们通常是用来设置队列的特殊特性,例如死信交换器和消息TTL。

确保消息不丢失并且正确处理,需要理解和利用RabbitMQ提供的各种特性。死信交换机和延迟队列是构建复杂消息系统的有力工具,可以帮助开发者优雅地处理消息失败、延迟和重新调度等场景。在实际应用中,可能需要结合重试逻辑、错误监控和告警系统,以确保系统的稳定性和可靠性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/665008.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Blender教程(基础)-面的切割-10

快捷键K切割&#xff0c;菜单选项切割. 一、随意切割 物体在编辑模式下&#xff0c;按键盘K建切割物体。 二、中点切割 先按K键&#xff0c;再按shift键&#xff0c;会自动吸附到每条边的中点进行切割。 三、取消吸附 切割时会自动吸附到顶点或边 关闭快速吸附 按K键再按…

26条prompt规则应用于大模型

1、引入动机 llm大模型在回答一些问题上表现出了惊人的能力&#xff0c;例如数学逻辑推理&#xff0c;代码生成&#xff0c;问题答复等。提词工程是和大预言模型交流的一门艺术。 大模型的返回结合和用户的指令和输入直接相关prompts是用户和大模型沟通的一种编码方式 一般地…

在低代码平台上实现精益软件开发:提高效率与灵活性的关键实践

什么是精益软件开发&#xff1f; 精益软件开发是一种敏捷的软件开发框架。它基于最小化浪费和最大化价值的原则。该框架基于最小可行产品策略运行&#xff0c;该策略强调交付具有基本基本功能的产品&#xff0c;然后根据收到的反馈进行迭代以即兴发挥并提供卓越。 精益软件开发…

2阶段提交_3阶段提交(phase-commit)

1. 2PC&#xff08;两阶段提交) 如上所示是2阶段提交的一个过程&#xff0c;可为什么要进行两阶段提交呢&#xff1f;这里主要来说是将操作事务能力和提交、回滚事务能力分开来做成2阶段&#xff0c;如果不分开会造成什么后果呢&#xff1a; 如果单纯 A 向 B 发送一个请求就以…

由于找不到d3dcompiler43.dll无法继续执行程序的解决方法

在日常使用电脑的过程中&#xff0c;我们常常会遭遇一些突发的技术问题&#xff0c;其中之一便是可能会遇到系统提示找不到d3dcompiler43.dll文件的情况。这一特定的动态链接库文件&#xff08;dll&#xff09;对于许多应用程序的正常运行至关重要&#xff0c;尤其是在涉及到图…

什么是Golang中的包循环问题?如何规避?

Go语言作为一门注重简洁和效率的编程语言&#xff0c;在设计上有着严格的规范和原则。其中一个突出的设计决策是禁止包循环。接下来将深入解释为何Go语言中不允许包循环&#xff0c;如何避免它&#xff0c;以及如何进行好的规划&#xff0c;通过实际开发案例和代码演示&#xf…

PPT母版页码设置

PPT母版页码设置 一、需求介绍二、达到效果三、具体操作1. 插入页码2. 设置起始页码为03. 进入母版编辑页面4. 内容格式调整5. 删去最后一个板式的三个模块信息6. 尾页处理7. 最终效果 一、需求介绍 PPT的母版可以设定PPT的基调&#xff0c;且在非母版页面不会误改PPT中的固定…

数据库管理-第143期 Oracle DB 19c需要调整的基本参数V2(20240202)

数据库管理143期 2024-02-08 数据库管理-第143期 Oracle DB 19c需要调整的基本参数V2&#xff08;20240202&#xff09;1 DRM2 readmostly objects3 内存大页4 CLUSTER_INTERCONNECTS5 db_files6 内存配置7 555.1总结 数据库管理-第143期 Oracle DB 19c需要调整的基本参数V2&am…

【笔记】Android 常用编译模块和输出产物路径

模块&产物路径 具体编译到软件的路径要看编译规则的分区&#xff0c;代码中模块编译输出的产物基本对应。 Android 代码模块 编译产物路径设备adb路径Comment 模块device/mediatek/system/common/ 资源overlay/telephony/frameworks/base/core 文件举例res/res/values-m…

大专考试,搜题最准的软件?搜题神器推荐,助力大学生学业! #其他#知识分享

下面&#xff0c;我将为您介绍几款备受大学生欢迎的搜题软件&#xff0c;希望能够帮助您更好地完成学业和提升学习效果。 1.Quizlet Quizlet是一款学习卡片和题库应用&#xff0c;可用于各种学科的学习和复习。通过Quizlet&#xff0c;学生可以创建自己的学习卡片&#xff0c…

Leetcode的AC指南 —— 栈与队列 :150. 逆波兰表达式求值

摘要&#xff1a; **Leetcode的AC指南 —— 栈与队列 &#xff1a;150. 逆波兰表达式求值 **。题目介绍&#xff1a;给你一个字符串数组 tokens &#xff0c;表示一个根据 逆波兰表示法 表示的算术表达式。 请你计算该表达式。返回一个表示表达式值的整数。 文章目录 一、题目…

GED(Generalized Error Distribution)广义误差分布

介绍 广义误差分布(GED)是指一类以整个实数轴为支撑集的连续分布&#xff0c;是由Box和Tiao在1973年提出的&#xff08;他们称该分布为the exponential power distribution), Harvey在1981年又提出了该分布并命名为GED. 该分布包含三个参数 μ ∈ R , a > 0 , b > 0 \m…

Redis核心技术与实战【学习笔记】 - 17.Redis 缓存异常:缓存雪崩、击穿、穿透

概述 Redis 的缓存异常问题&#xff0c;除了数据不一致问题外&#xff0c;还会面临其他三个问题&#xff0c;分别是缓存雪崩、缓存击穿、缓存穿透。这三个问题&#xff0c;一旦发生&#xff0c;会导致大量的请求积压到数据库。若并发量很大&#xff0c;就会导致数据库宕机或故…

TQ15EG开发板教程:开发板Vivado硬件设置

1&#xff0c;串口的配置 PS端有2个串口,在BANK500, 1.8V IO电平 管脚名称 电平 说明 UART0 RX MIO18 1.8V MPSOC方向看 TX MIO19 1.8V UART1 RX MIO21 1.8V TX MIO20 1.8V 2&#xff0c;QSPI的配置 采用2片MT25QU256 拼接成8bit的QSPI存储系统。采用1.8V…

安卓SurfaceTexture中updateTexImage使用及源码分析

文章目录 引言updateTexImage 简单使用SurfaceTexture 初始化相关源码分析Surface 绘制流程源码分析createBufferQueue 源码分析SurfaceTexture 之 updateTexImage 源码分析结尾 本文首发地址 https://h89.cn/archives/140.html 最新更新地址 https://gitee.com/chenjim/chenji…

中国象棋基础

帅&#xff08;将&#xff09;的运用原则&#xff1a; &#xff08;1&#xff09;帅走直线&#xff0c;前进后退均可 &#xff08;2&#xff09;一次只能走一格 &#xff08;3&#xff09;活动范围在“九宫”之内 &#xff08;4&#xff09;可行处可吃敌子 &#xff08;5&…

React实例之完善布局菜单(一)

今天我们来用所学的知识来做一个布局菜单的组件, 针对这个组件我之前写过一个教程 React之布局菜单-CSDN博客&#xff0c;那个呢比较基础&#xff0c;这节课算是对那个教程的一个扩展和补充。这个实例讲完&#xff0c;这个系列就算告一段落了。先看效果 这个教程要求对React知识…

算法学习——华为机考题库6(HJ36 - HJ40)

算法学习——华为机考题库6&#xff08;HJ36 - HJ40&#xff09; HJ36 字符串加密 描述 有一种技巧可以对数据进行加密&#xff0c;它使用一个单词作为它的密匙。下面是它的工作原理&#xff1a;首先&#xff0c;选择一个单词作为密匙&#xff0c;如TRAILBLAZERS。如果单词中…

DDD技术方案落地实践

DDD技术方案落地实践 引言 从接触领域驱动设计的初学阶段&#xff0c;到实现一个旧系统改造到DDD模型&#xff0c;再到按DDD规范落地的3个的项目。对于领域驱动模型设计研发&#xff0c;从开始的各种疑惑到吸收各种先进的理念&#xff0c;目前在技术实施这一块已经基本比较成…

编程笔记 html5cssjs 073 JavaScrip Object数据类型

编程笔记 html5&css&js 073 JavaScrip Object数据类型 一、创建 Object二、Object 类型的属性与方法三、示例四、参考小结 JavaScript 中的 Object 数据类型是该语言中最复杂也最灵活的数据类型之一&#xff0c;它是其他所有内置对象和用户自定义对象的基础。在 JavaSc…