RabbitMQ 消息队列的工作模式

RabbitMQ 提供了多种工作模式,按照官网的描述,实际上可以分为七种模式

简单模式
  • 作用: 生产者将消息发送到队列,消费者从队列中获取消息。每条消息只能被一个消费者消费。

  • 适用场景: 适用于消息量较小且不需要复杂路由逻辑的场景。

RabbitMQ 提供了多种工作模式,按照官网的描述,实际上可以分为七种模式

工作队列模式
  • 作用: 通过多个消费者分担任务,达到负载均衡的目的。是一种竞争关系的模式,多个消费者之间是竞争关系,即一条消息如果被某个消费者消费了,那么其他的消费者就获取不到了。

  • 适用场景: 适用于需要并行处理大量独立任务的场景,如图像处理、视频转码等

发布/订阅模式
  • 作用: 消息发布到交换机,所有绑定到该交换机的队列都会收到消息。常用的交换机类型是 fanout。

  • 适用场景: 适用于广播消息的场景,如日志处理、事件通知等

路由模式
  • 作用: 消息发布到交换机,并根据路由键将消息发送到相应的队列。以此去匹配交换机和队列的绑定,常用的交换机类型是 direct.

  • 适用场景: 适用于需要对消息进行分类处理的场景,如日志系统中按严重级别分类的日志处理。

主题模式
  • 作用: 消息发布到交换机,并根据路由键模式( 通配符匹配 )将消息发送到相应的队列。常用的交换机类型是topic。

  • 适用场景: 适用于需要根据复杂的路由规则对消息进行分类处理的场景,如日志系统中按模块和严重级别分类的日志处理。

RPC 模式

作用: 实现远程过程调用,客户端发送请求消息到队列,服务器端处理后返回响应消息。 适用场景: 适用于需要实现远程服务调用的场景,如微服务之间的通信。

发布确认模式
  • 作用: 用于确保消息已经成功地发布并被 broker 接收。它提供了一种轻量级的方法来确认消息的持久性和可靠性,适用于需要高可靠性消息传递的场景。

  • 适用场景: 金融交易、订单处理等确保消息被可靠地传递和处理,防止丢失的场景。

相关推荐
小马爱打代码1 小时前
zookeeper:一致性原理和算法
分布式·zookeeper·云原生
Cikiss3 小时前
图解 bulkProcessor(调度器 + bulkAsync() + Semaphore)
java·分布式·后端·elasticsearch·搜索引擎
小马爱打代码3 小时前
zookeeper:架构原理和使用场景
分布式·zookeeper·架构
Logintern094 小时前
【学习篇】Redis 分布式锁
redis·分布式·学习
一叶飘零_sweeeet4 小时前
从 0 到 1 搭建实时数据看板:RabbitMQ+WebSocket 实战指南
java·websocket·rabbitmq·数据看板
失散1319 小时前
分布式专题——33 一台新机器进行Web页面请求的历程
分布式·tcp/ip·http·路由器·交换机
稚辉君.MCA_P8_Java1 天前
kafka解决了什么问题?mmap 和sendfile
java·spring boot·分布式·kafka·kubernetes
沐浴露z1 天前
分布式场景下防止【缓存击穿】的不同方案
redis·分布式·缓存·redission
zhuyasen1 天前
让压测回归简单:体验 PerfTest 分布式模式的“开箱即用”
分布式·压力测试
jackaroo20201 天前
后端_Redis 分布式锁实现指南
数据库·redis·分布式