rabbitmq实战系列3--springboot整合rabbitmq实现优先级队列

优先队列的注意点:

只有当消费者不足,即消息无法被即使消费而阻塞的时候,优先队列才会根据优先级来分配任务的执行顺序.

**

步骤:

1配置类:



@Configuration
public class priQueue {
    private static final String EXCHANGE = "priority-exchange";

    public static final String QUEUE = "priority-queue";

    private static final String ROUTING_KEY = "priority.queue";
    @Bean
    DirectExchange exchange1(){
        return new DirectExchange(EXCHANGE);
    }
    @Bean
    Queue queue1(){
        Map<String,Object>map = new HashMap<>();
        map.put("x-max-priority",10);//设置最大的优先级数量
        return new Queue(QUEUE,true,false,false,map);
    }
    @Bean
    public Binding binding1(){
        return BindingBuilder.bind(queue1()).to(exchange1()).with(ROUTING_KEY);
    }
}

2生产者


@Component
public class priConsumer {
    private static final String EXCHANGE = "priority-exchange";

    public static final String QUEUE = "priority-queue";

    private static final String ROUTING_KEY = "priority.queue";
    @Autowired
    RabbitTemplate template;
    public void test(){
        for(int i=10;i>1;i--){
            int finalI = i;
            template.convertAndSend(EXCHANGE,ROUTING_KEY,"queue:"+i, message -> {
                message.getMessageProperties().setPriority(finalI);
                return message;
            });
        }

    }
}

3消费者:

@Component
@RabbitListener(queues ="priority-queue")
public class pricon {
    @RabbitHandler
    public void hand(String str){
        System.out.println("接受到了一个消息:"+str);
    }
}

4测试类

5结果
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
要基于RabbitMQ实现优先级队列,需要使用插件rabbitmq_priority_queue,该插件提供了消息优先级队列的支持。以下是添加队列的步骤: 1. 确保RabbitMQ服务器上已经安装了rabbitmq_priority_queue插件。如果没有安装,需要执行以下命令安装: ``` rabbitmq-plugins enable rabbitmq_priority_queue ``` 2. 使用AMQP客户端连接到RabbitMQ服务器,并创建队列时,通过设置x-max-priority参数来指定最大优先级数。例如,以下是使用Python pika库创建一个具有10个优先级级别的队列的示例代码: ```python import pika connection = pika.BlockingConnection(pika.ConnectionParameters('localhost')) channel = connection.channel() args = {"x-max-priority": 10} channel.queue_declare(queue='my_queue', arguments=args) connection.close() ``` 在上面的示例中,我们将队列命名为my_queue,并通过args参数将x-max-priority设置为10。 3. 发布消息时,需要在消息属性中设置priority属性,指定该消息的优先级。例如,以下是使用Python pika库发布消息并指定优先级的示例代码: ```python import pika connection = pika.BlockingConnection(pika.ConnectionParameters('localhost')) channel = connection.channel() properties = pika.BasicProperties(priority=5) channel.basic_publish(exchange='', routing_key='my_queue', body='Hello, World!', properties=properties) connection.close() ``` 在上面的示例中,我们通过properties参数将priority属性设置为5,指定该消息的优先级为5。 通过上述步骤,我们就可以基于RabbitMQ实现优先级队列了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值