SpringAMQP Work Queue 工作队列

消息模型:

代码模拟:

相较于之前的基础队列,该队列新增了消费者 不再是一个,所以我们通过代码模拟出两个consumer消费者。在原来的消费者类里写两个方法 其中消费者1效率高 消费者2效率低

@RabbitListener(queues = "simple.queue")
    public void lintestWorkQueue50(String mes) throws InterruptedException {
        System.out.println("消费者1接收到了消息:" + mes +"     "+ LocalDateTime.now());
        Thread.sleep(20);
    }


    @RabbitListener(queues = "simple.queue")
    public void lintestWorkQueue10(String mes) throws InterruptedException {
        System.err.println("消费者2接收到了消息:" + mes + "     "+LocalDateTime.now());
        Thread.sleep(200);
    }

在publisher提供者编写测试方法 一次发送50条消息 

发送后让观察控制台消费者处理情况 会发现两者处理的效率不一样但是处理的消息是平均分配的,一人25条,这是因为Rabbit有个预取机制,不管执行消费者效率,消费者都会提前在队列里预取一个消息,最后效果就是平均分配。

这个预取机制可以在yml配置里修改。

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-12 12:56:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-12 12:56:03       101 阅读
  3. 在Django里面运行非项目文件

    2024-05-12 12:56:03       82 阅读
  4. Python语言-面向对象

    2024-05-12 12:56:03       91 阅读

热门阅读

  1. 【AMBA Bus ACE 总线 9 -- Non-cache IO device】

    2024-05-12 12:56:03       33 阅读
  2. 编译OpenResty遇到找不到OpenSSL的解决办法

    2024-05-12 12:56:03       34 阅读
  3. 汇编个位数求和实验

    2024-05-12 12:56:03       36 阅读
  4. Python梯度下降算法

    2024-05-12 12:56:03       35 阅读
  5. pat乙1030

    2024-05-12 12:56:03       29 阅读
  6. GitLab CI/CD的原理及应用详解(三)

    2024-05-12 12:56:03       29 阅读
  7. Mysql中的DML

    2024-05-12 12:56:03       33 阅读
  8. springboot 连接hive的坑

    2024-05-12 12:56:03       37 阅读
  9. Ubuntu防火墙配置:如何封禁黑客攻击源IP

    2024-05-12 12:56:03       36 阅读