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来控制消费者预取的消息数量

相关推荐
不能再留遗憾了35 分钟前
RabbitMQ 高级特性——消息分发
分布式·rabbitmq·ruby
duration~38 分钟前
Maven随笔
java·maven
zmgst41 分钟前
canal1.1.7使用canal-adapter进行mysql同步数据
java·数据库·mysql
茶馆大橘44 分钟前
微服务系列六:分布式事务与seata
分布式·docker·微服务·nacos·seata·springcloud
跃ZHD1 小时前
前后端分离,Jackson,Long精度丢失
java
blammmp1 小时前
Java:数据结构-枚举
java·开发语言·数据结构
暗黑起源喵2 小时前
设计模式-工厂设计模式
java·开发语言·设计模式
WaaTong2 小时前
Java反射
java·开发语言·反射
九圣残炎2 小时前
【从零开始的LeetCode-算法】1456. 定长子串中元音的最大数目
java·算法·leetcode
wclass-zhengge2 小时前
Netty篇(入门编程)
java·linux·服务器