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

【RabbitMQ的死信队列】

死信队列

  • 什么是死信队列
    • 死信队列的配置方式
    • 死信消息结构

什么是死信队列

  1. 消息被消费者确认拒绝。消费者把requeue参数设置为true(false),并且在消费后,向RabbitMQ返回拒绝。channel.basicReject或者channel.basicNack。
  2. 消息达到预设的TTL时限还一直没有被消费。TTL时长可能是制队列的本身特性,也可能是消息的特性。

可以通过配置策略的方式实现:
rabbitmqctl set_policy TTL ".*" '{"message-ttl":60000}' --apply-to queues

也可以通过创建队列的时候声明,java代码如下:

Map<String, Object> args = new HashMap<String, Object>();
args.put("x-message-ttl", 60000);
channel.queueDeclare("myqueue", false, false, false, args);
  1. 消息由于队列已经达到最长长度限制而被丢掉

死信队列的配置方式

RabbitMQ中有两种方式可以声明死信队列,一种是针对某个单独队列指定对应的死信交换机,这个交换机也要绑定队列。另一种就是以
策略的方式进行批量死信队列的配置。

通过代码的方式给队列声明死信交换机

        Channel channel = openChannel();
        Map<String, Object> params = new HashMap<>();
        params.put("x-message-ttl", 60000);
        // 死信交换机的名称
        params.put("x-dead-letter-exchange", "deadletterexchange");
        // 死信队列的路由键
        params.put("x-dead-letter-routing-key", "dde");
        AMQP.Queue.DeclareOk declareOk = channel.queueDeclare(queueName, true, false, false, params);
        channel.queueBind(queueName,"test1","ddeorigin");

针对多个队列,可以使用策略方式,配置统一的死信队列。
rabbitmqctl set_policy DLX ".*" '{"dead-letter-exchange":"my-dlx"}' --apply-to queues

死信消息结构

在这里插入图片描述


http://www.kler.cn/a/456324.html

相关文章:

  • vue在action中调用action的函数
  • 日本IT行业|分享实用的开发语言及框架
  • 探索 Java 静态变量(static)的奥秘
  • leetcode 1649. 通过指令创建有序数组
  • 基于 DINOv2 模型实现图搜图相似度检索任务
  • Unity3D中Huatuo可行性的思维实验详解
  • CCF-GESP 等级考试 2023年12月认证C++二级真题解析
  • firefly rk3588s+qt+海康摄像头部分问题记录
  • Java中的Servlet
  • Java容器都有哪些?
  • 时序论文34|AdaWaveNet:用于时间序列分析的自适应小波网络
  • 【代数学6】基于数域筛法对大整数进行分解
  • 【小程序】自定义组件的data、methods、properties
  • Kafka高可用机制总结
  • Linux-frp_0.61.1内网穿透的配置和使用
  • 数据结构与算法(JAVA语言版解密)
  • CDN(Content Delivery Network,内容分发网络)
  • 浏览器语音视频功能
  • 【每日学点鸿蒙知识】webview性能优化、taskpool、热更新、Navigation问题、调试时每次都卸载重装问题
  • Flume和Kafka的区别?
  • PlasmidFinder:质粒复制子的鉴定和分型
  • 进军AI大模型-环境配置
  • Redis 数据类型全解析:基础与进阶应用场景
  • 【PHP】部署和发布PHP网站到IIS服务器
  • 如何安全删除 GitHub 提交记录及其操作步骤
  • 2848、与车相交的点