当前位置:   article > 正文

RabbitMQ系列【13】优先级队列_rabbitmq优先级队列

rabbitmq优先级队列

有道无术,术尚可求,有术无道,止于术。

前言

RabbitMQ将消息写入队列中都是按顺序写的,消费时也是按顺序进行消费,队列中的消息是先进先出(FIFO).。在这里插入图片描述
首先测试一下没有优先级的效果。先注释掉所有的消费者,不然发一个就消费一个,看不出优先级的效果,只有消息堆积在一起时,才能看到效果。

先发送10条消息:
在这里插入图片描述
发送完成后,再开启消费者进行消费,没有设置优先级,那么先到达队列的消息先消费,收到的消息会从按照0-9的顺序消费。可以看到其时按照投递顺序消费,先进先出:
在这里插入图片描述
在一些场景中我们需要将某些消息优先处理,也就是设置优先级,优先级高的消息优先被消费。

1. 设置优先级队列

可以直接在控制台,设置队列的最大优先级,优先级的取值范围为0~255,一般设置最大值为10
在这里插入图片描述
添加优先级后,可以在队列中看到Pri标记:
在这里插入图片描述
在代码中,可以添加 x-max-priority参数设置:

    @Bean("priorityQueue")
    public Queue priorityQueue() {
        Map<String, Object> arguments = new HashMap<>();
        arguments.put("x-max-priority", 10);
        return QueueBuilder.durable("priorityQueue").withArguments(arguments).build();
    }

	@Bean("priorityExchange")
    public Exchange priorityExchange() {
        return ExchangeBuilder.directExchange("priorityExchange").durable(true).build();
    }

    @Bean("priorityBinding")
    public Binding priorityBinding(@Qualifier("priorityQueue") Queue priorityQueue, @Qualifier("priorityExchange") Exchange priorityExchange) {
        return BindingBuilder.bind(priorityQueue).to(priorityExchange).with("priority.key").noargs();
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

也可以使用maxPriority方法设置:

    @Bean("priorityQueue")
    public Queue priorityQueue() {
        // maxPriority 设置最大优先级
        return QueueBuilder.durable("priorityQueue").maxPriority(10).build();
    }
  • 1
  • 2
  • 3
  • 4
  • 5

2. 消息设置优先级

设置完优先级队列后,发送消息时,需要设置优先级。

这里循环发送十条消息,优先级从 0~9 递增:

        for (int i = 0; i < 10; i++) {
            MessageProperties messageProperties = new MessageProperties();
            messageProperties.setPriority(i); // 设置优先级
            System.out.println("发送消息,优先级为:"+i);
            Message message = new Message(("消息优先级为:"+i).getBytes(), messageProperties);
            TimeUnit.SECONDS.sleep(1);
            rabbitTemplate.send("priorityExchange", "priority.key", message);
        }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

发送消息:

在这里插入图片描述
开启消费者消费,可以看到优先级高的优先被消费:
在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小桥流水78/article/detail/763240
推荐阅读
相关标签
  

闽ICP备14008679号