rabbitmq 死信队列,延迟队列,优先级队列

本文详细介绍了RabbitMQ中死信队列的原理及应用,包括消息过期、消息被拒绝和队列达到最大长度三种场景。同时,通过代码示例展示了如何配置死信队列和延迟队列,以及如何使用优先级队列。

死性队列:

延迟队列:死信队列通过过期时间实现就是延迟队列,消息发送到正常队列,等待过期,等待rabbitmq将正常队列中的消息投递到死信队列中,消费自己消费死信队列

优先级队列:x-max-priority指定优先级

package com.rabbitmq.demo;

import com.rabbitmq.client.*;

import java.util.HashMap;
import java.util.Map;

public class TtlProduce {
    public static void main(String args[])  throws Exception{
        ConnectionFactory connectionFactory=new ConnectionFactory();
        connectionFactory.setPassword("guest");
        connectionFactory.setPassword("guest");
        connectionFactory.setHost("192.168.1.141");
        connectionFactory.setPort(5672);
        Connection connection=connectionFactory.newConnection();
        Channel channel= connection.createChannel();
        /**
         * 死信队列出现原因
         * 消息被拒绝 (Basic.Reject/Basic .Na ck) ,井且设置 requeue 参数为 alse;
         * 消息过期;
         * 队列达到最大长度。
         */
        //死信队列
        channel.exchangeDeclare("exchange.dlx" , "direct" , true);
        //正常队列,先发送消息到正常队列,
        channel.exchangeDeclare( "exchange.normal" , "fanout" , true);
        Map<String , Object> map = new HashMap<String, Object>( );
        //消息在正常队列过期时间
        map.put("x-message-ttl" , 10000);
        //通过x-max-priority指定优先级队列
        map.put("x-max-priority" ,10) ;
//关联的死信队列
        map.put("x-dead-letter-exchange" , "exchange.dlx");
        // 死信队列路由key
        map.put("x-dead-letter-routing-key" , "routingkey");
        //正常队列绑定exchange
        channel.queueDeclare("queue.norma1" ,true ,false,false, map);
        channel.queueBind("queue.norma1" , "exchange.normal" , "");
        // 死信队列绑定exchang
        channel.queueDeclare("queue.d1x" , true , false , false , null) ;
        channel.queueBind("queue.d1x" ,"exchange.dlx" ,"routingkey");
                channel.basicPublish( "exchange.normal" , "rk" ,
                        MessageProperties.PERSISTENT_TEXT_PLAIN, "dlx" .getBytes()) ;
    }
}

管理端展示效果:

4db1b11e911c1467d4bb86f8ca058c32e4a.jpg

等待时间过期后:

8dbfabad800e15b830b5adef6926aa11b0a.jpg

转载于:https://my.oschina.net/xppba/blog/3079815

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值