RabbitMq消息模型-队列消息

队列消息分为2种:

  • 基本模型(SimpleQueue)、工作模型(WorkQueue)

队列消息特点:

  1. 消息不会丢失 并且 有先进先出的顺序。
  2. 消息接收是有顺序的,不是随机的,仅有一个消费者能拿到数据,而且不同消费者拿不到同一份数据。

基本模型: SimpleQueue

在上图的模型中,有以下几个概念:

  • P:为生产者,也就是要发送消息的程序
  • C:为消费者:消息的接受者,会一直等待消息到来。
  • queue:为消息队列,为上图中间红色部分。类似为一个邮箱,可以缓存消息,生产者向其中投递消息,消费者从其中取出消息。

适用场景:基本模型适用于 消息存取 数量不多,频率不高。

工作模型: WorkQueue

WorkQueue简单来说就是让多个消费者绑定到一个队列,共同消费队列中的消息

弊端:

当消息处理比较耗时的时候,可能生产消息的速度会远远大于消息的消费速度。长此以往,消息就会堆积越来越多,无法及时处理。那么这时就可以用WorkQueue模型,多个消费者共同处理消息,处理消息的速度就能大大提高了。

工作模型它默认分配模式是 平均分配给每个消费者,并没有考虑到消费者的处理能力。这样显然是有问题的。有的消费者性能高,有的消费者性能低。如果两个消费者都消费同样的消息,那么就会造成一个消费的快些一个消费的慢些,因为性能高的消费者它的消费能力要强些,性能低的消费者消费能力要弱些。

当然默认的平均分配模式也可以在消费者的配置文件中更改为能者多劳模式,能力强的多干点,能力弱的少干点。

适用场景:工作模型适用于 消息存取 数量多,频率高。

相关推荐
‘胶己人’25 分钟前
redis分布式锁
数据库·redis·分布式
山沐与山27 分钟前
【MQ】Kafka与RocketMQ深度对比
分布式·kafka·rocketmq
武子康41 分钟前
Java-203 RabbitMQ 生产者/消费者工作流程拆解:Connection/Channel、默认交换器、ACK
java·分布式·消息队列·rabbitmq·erlang·ruby·java-rabbitmq
小满、1 小时前
RabbitMQ: 同步异步解析、安装与控制台实践
分布式·消息队列·rabbitmq·mq
山沐与山1 小时前
【RabbitMQ】架构与集群模式详解
架构·rabbitmq·ruby
小满、2 小时前
RabbitMQ:AMQP 原理、Spring AMQP 实战与 Work Queue 模型
java·rabbitmq·java-rabbitmq·spring amqp·amqp 协议·work queue
金海境科技3 小时前
【服务器数据恢复】数据中心私有云Ceph分布式集群文件丢失数据恢复案例
服务器·经验分享·分布式·ceph
音符犹如代码3 小时前
ZooKeeper 实战指南:从入门到场景解析
分布式·微服务·zookeeper·云原生·中间件·架构
树下水月3 小时前
Easyoole 使用rdkafka 进行kafka的创建topic创建 删除 以及数据发布 订阅
分布式·kafka
Wang's Blog3 小时前
RabbitMQ: MessageListenerAdapter 的核心作用与设计原理
rabbitmq