RabbitMQ - 03 - Work消息模型

目录

部署demo项目

什么是Work消息模型

实现Work消息模型

1.创建队列

2.生产者代码

3.消费者代码

4.配置yml


部署demo项目

通过消息队列demo项目进行练习 相关配置看此贴 http://t.csdnimg.cn/hPk2T

注意 生产者消费者的yml文件也要配置好

什么是Work消息模型

工作(Work)消息模型是一种基本的消息队列模型,也称为任务队列模型。在工作消息模型中,多个消费者(workers)同时监听同一个队列,其中的消息将被平均分配给不同的消费者进行处理。

工作消息模型的特点包括:

  1. 消息队列:生产者将消息发送到一个共享的队列中。
  2. 多个消费者 :多个消费者同时监听这个队列,竞争消费消息。
  3. 消息分发 :消息将按照一定的算法均匀地分发给不同的消费者,每个消息只能被消费一次。
  4. 负载均衡:通过多个消费者来处理消息,实现负载均衡,提高系统的处理能力和效率。

在工作消息模型中,消息的处理是并发的,多个消费者可以同时处理不同的消息,从而加快消息处理速度。然而,由于消息的分发是平均的,可能会导致某些消费者处理的消息比较多,而其他消费者处理的消息比较少,因此在实际应用中需要根据业务需求和系统性能进行合理的调整和优化。

实现Work消息模型

1.创建队列

2.生产者代码

java 复制代码
package cn.itcast.mq.helloworld;

import org.junit.jupiter.api.Test;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.messaging.Message;
import org.springframework.messaging.converter.StringMessageConverter;

@SpringBootTest
public class SpringAMQPTest {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    //  work消息模型
    @Test
    void testWorkQueue() throws InterruptedException {
        String queueName = "work.queue";
        for (int i = 1; i < 51; i++) {
            String message = "hello, Work MQ - " + i;
            rabbitTemplate.convertAndSend(queueName,message);
            Thread.sleep(20);
        }
    }


}

3.消费者代码

java 复制代码
package cn.itcast.mq.lintener;

import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

@Slf4j
@Component
public class MQListener {

    @RabbitListener(queues = "work.queue")
    public void listenWorkQueue1(String message) throws InterruptedException {
        log.info("消费者1收到了消息:........... {}", message);
        Thread.sleep(20);  // 每秒处理 50 条消息
//        System.out.println("消费者收到了消息: " + message);
    }

    @RabbitListener(queues = "work.queue")
    public void listenWorkQueue2(String message) throws InterruptedException {
        log.info("消费者2收到了消息: {}", message);
        Thread.sleep(200);     //   每秒处理 5 条消息
//        System.out.println("消费者收到了消息: " + message);
    }

}

4.配置yml

消费者的yml需要补充下面的配置

work消息模型是采用轮询的方式获取消息队列的消息的,如果一个服务器性能高,另一个低,性能高的就得等待性能低的读取完后才能接着读取下一个

加上这些代码就能实现能者多劳,性能高的多读取

如图 消息2读取一条 消息1已经读取了6条了

总结

Work模型的使用:

  • 多个消费者绑定到一个队列,同一条消息只会被一个消费者处理

  • 通过设置prefetch来控制消费者预取的消息数量

相关推荐
武子康32 分钟前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
YuTaoShao3 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
源码_V_saaskw4 小时前
JAVA图文短视频交友+自营商城系统源码支持小程序+Android+IOS+H5
java·微信小程序·小程序·uni-app·音视频·交友
超浪的晨4 小时前
Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
java·开发语言·后端·学习·个人开发
双力臂4044 小时前
Spring Boot 单元测试进阶:JUnit5 + Mock测试与切片测试实战及覆盖率报告生成
java·spring boot·后端·单元测试
Edingbrugh.南空5 小时前
Aerospike与Redis深度对比:从架构到性能的全方位解析
java·开发语言·spring
QQ_4376643145 小时前
C++11 右值引用 Lambda 表达式
java·开发语言·c++
永卿0015 小时前
设计模式-迭代器模式
java·设计模式·迭代器模式
誰能久伴不乏5 小时前
Linux如何执行系统调用及高效执行系统调用:深入浅出的解析
java·服务器·前端
itLaity6 小时前
基于Kafka实现简单的延时队列
spring boot·分布式·kafka