小飞知识库 | YeLu🤠MiLu🤪 小飞知识库 | YeLu🤠MiLu🤪
  • 函数式编程
  • Spring
  • SpringMVC
  • SpringBoot
  • SpringCloud
  • Mybatis
  • JVM
  • JUC并发编程
  • 设计模式
  • 单元测试
  • Redis
  • RabbitMQ
  • mysql
  • oracle
  • linux
  • nginx
  • docker
  • elasticSearch
  • windows
  • 虚拟机
  • 监控系统
  • https
  • 内网穿透
  • 前端文章

    • JavaScript
  • 页面

    • HTML
    • CSS
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • TypeScript
    • JS设计模式总结
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 版本管理

    • Git笔记
  • 项目构建

    • maven
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
  • JAR包相关
  • 关于
  • 收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

YeLu

爱技术的YeLu🤠
  • 函数式编程
  • Spring
  • SpringMVC
  • SpringBoot
  • SpringCloud
  • Mybatis
  • JVM
  • JUC并发编程
  • 设计模式
  • 单元测试
  • Redis
  • RabbitMQ
  • mysql
  • oracle
  • linux
  • nginx
  • docker
  • elasticSearch
  • windows
  • 虚拟机
  • 监控系统
  • https
  • 内网穿透
  • 前端文章

    • JavaScript
  • 页面

    • HTML
    • CSS
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • TypeScript
    • JS设计模式总结
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 版本管理

    • Git笔记
  • 项目构建

    • maven
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
  • JAR包相关
  • 关于
  • 收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • RabbitMQ

    • 介绍
    • 安装
    • 卸载
    • 基础使用

    • 高级使用

      • confirm机制
      • return机制
      • limit_requeue
      • ttl
      • 死信队列 [dead-letter]
      • 消息传输的一致性问题
      • Springboot整合RabbitMQ
  • 消息队列
  • RabbitMQ
  • 高级使用
YeLu🤠
2025-01-06

死信队列 [dead-letter]

参考demo:G:\学习资料\java\java学习文档\java技术文档\消息队列文档\rabbimitmq\cd-xufei-rabbiitmq-parent\cd-xufei-rabbitmq-01 => dl

死信队列的逻辑:

什么是死信?

产生死信的三种情况:

  • 队列满了 ----> 如果再出现消息往队列中放 那么就会出现消息死信
  • RabbitMQ 拒绝了这个消息(消息没有地方去) -----> 也出现了死信
  • TTL中时间满了 那么这个消息 没地方去 也将成为死信

其实就是普通队列,需要将其他普通队列添加死信队列的属性,这样其他队列产生死信的时候,就会将这些消息放到关联的死信队列中,这样我们的消费者就能从死信队列中消费消息了

生产者示例:

public class Producer {

    /**
     * 申明了一个交换机的名字
     */
    private static final String EXCHANGE_NAME = "exchange_dl";

    public static void main(String[] args) throws Exception {
        Connection connection = ConnectionUtils.getConnection();
        Channel channel = connection.createChannel();
        // 需要申明咋们的交换机
        /**
         * 第一个参数:交换机的名字
         * 第二个参数:交换机的类型  这里要注意  发布订阅模型的话 这里的类型是不能乱写的 只能是 fanout
         */
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
        // 接下来发送数据到交换机
        channel.basicPublish(EXCHANGE_NAME, "", null, ("模拟死信队列").getBytes());
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

消费者示例:

public class Consumer1 {

    /**
     * 申明了一个交换机的名字
     */
    private static final String EXCHANGE_NAME = "exchange_dl";
    /**
     * 与交换机绑定的这个队列
     */
    private static final String QUEUE_NAME = "exchange_dl_queue";

    // 下面设置死信的交换机 和死信的队列
    /**
     * 死信的交换机
     */
    private static final String DLX_EXCHANGE_NAME = "exchange_dlx_0001";
    /**
     * 死信的队列
     */
    private static final String DLX_QUEUE_NAME = "exchange_dlx_0001_queue";


    public static void main(String[] args) throws Exception {
        // 获取连接
        Connection connection = ConnectionUtils.getConnection();
        Channel channel = connection.createChannel();

        Map<String, Object> maps = new HashMap<>();
        maps.put("x-message-ttl", 5000);// 要将正常的队列设置成TTL队列
        // 给普通队列 添加一个死信队列的属性 后面的名字是死信队列交换机的名称
        maps.put("x-dead-letter-exchange", DLX_EXCHANGE_NAME);

        // 申明队列
        channel.queueDeclare(QUEUE_NAME, false, false, false, maps);
        // 申明交换机
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
        // 下面将队列绑定到交换机
        /**
         * 第一个参数:队列的名字
         * 第二个参数:交换机的名字
         * 第三个参数:路由的这个key
         */
        channel.queueBind(QUEUE_NAME, EXCHANGE_NAME, "xff");


        // 申明死信的交换机
        // 申明队列
        channel.queueDeclare(DLX_QUEUE_NAME, false, false, false, maps);
        // 申明交换机
        channel.exchangeDeclare(DLX_EXCHANGE_NAME, "fanout");
        // 将死信的队列和死信的交换机绑定到一起
        channel.queueBind(DLX_QUEUE_NAME, DLX_EXCHANGE_NAME, "xff");


        // 申明一个消费者
        DefaultConsumer defaultConsumer = new DefaultConsumer(channel) {
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                System.out.println("接受了来自死信队列的数据:" + new String(body));
            }
        };

        // 将消费者 绑定到 死信队列
        channel.basicConsume(DLX_QUEUE_NAME, true, defaultConsumer);
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
最近更新: 2025/07/30, 15:37:56
ttl
消息传输的一致性问题

← ttl 消息传输的一致性问题→

最近更新
01
服务端配置
07-30
02
frp 安装
07-30
03
Prometheus采集Springboot应用
02-20
更多文章>
Theme by Vdoing | Copyright © 2019-2025 | YeLu🤠MiLu🤪 | MIT License 蜀ICP备2024116879号 | 川公网安备51012202001998号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
欢迎你,我的朋友
看板娘