RabbitMQ 死信队列

死信的来源:
(1)消息TTL过期
(2)队列满了
(3)消息被拒绝(basic.reject 或 basic.nack)并且requeue=false

死信队列:放死信的队列称为死信队列

应用:在商城下单成功并点击去支付后在指定时
间未支付时自动失效->放入死信队列

主体代码思路:
c1:
声明交换机:normal_exchange、dead_exchange
声明队列:normal_queue、dead_queue(定义normal_queue时额外指定死信的交换机与路由)
绑定交换机与队列:normal_exchange&normal_queue、dead_exchange&dead_queue

//声明交换机 类型为direct
channel.exchangeDeclare(NORMAL_EXCHANGE, BuiltinExchangeType.DIRECT);
channel.exchangeDeclare(DEAD_EXCHANGE, BuiltinExchangeType.DIRECT);

//声明队列
channel.queueDeclare(DEAD_QUEUE, false, false, false, null);
Map<String, Object> params = new HashMap<>();
params.put("x-dead-letter-exchange", DEAD_EXCHANGE);
params.put("x-dead-letter-routing-key", "lisi");
channel.queueDeclare(NORMAL_QUEUE, false, false, false, params);

//绑定交换机与队列
channel.queueBind(DEAD_QUEUE, DEAD_EXCHANGE, "lisi");
channel.queueBind(NORMAL_QUEUE, NORMAL_EXCHANGE, "zhangsan");

1.消息TTL过期
producer端发送消息时设置消息的TTL时间(Time To Live)
//设置消息的 TTL 时间
AMQP.BasicProperties properties = new AMQP.BasicProperties().builder().expiration("10000").build();
channel.basicPublish(NORMAL_EXCHANGE, "zhangsan", properties, message.getBytes());

2.队列满了
Map<String, Object> params = new HashMap<>();
params.put("x-max-length", 6);
//设置队列最大长度
params.put("x-dead-letter-exchange", DEAD_EXCHANGE);
params.put("x-dead-letter-routing-key", "lisi");
channel.queueDeclare(NORMAL_QUEUE, false, false, false, params);

3.消息被拒并不放回队列
DeliverCallback deliverCallback = (consumerTag, delivery) -> {
    String message = new String(delivery.getBody(), "UTF-8");
    if (message.equals("info5")) {
        System.out.println("Consumer接收到消息:" + message + ",并拒绝签收该消息");
        //requeue=false不重新入队,如果配置了死信交换机将发送到死信队列中
        channel.basicReject(delivery.getEnvelope().getDeliveryTag(), false);
    } else {
        System.out.println("Consumer接收到消息:" + message);
        channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);
    }
};

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值