RabbitMQ 消息队列的工作模式

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

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

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

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

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

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

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

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

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

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

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

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

RPC 模式

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

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

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

相关推荐
ALex_zry8 小时前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存
为什么不问问神奇的海螺呢丶10 小时前
n9e categraf rabbitmq监控配置
分布式·rabbitmq·ruby
TTBIGDATA14 小时前
【Atlas】Atlas Hook 消费 Kafka 报错:GroupAuthorizationException
hadoop·分布式·kafka·ambari·hdp·linq·ranger
m0_6873998416 小时前
telnet localhost 15672 RabbitMQ “Connection refused“ 错误表示目标主机拒绝了连接请求。
分布式·rabbitmq
陌上丨17 小时前
生产环境分布式锁的常见问题和解决方案有哪些?
分布式
新新学长搞科研17 小时前
【智慧城市专题IEEE会议】第六届物联网与智慧城市国际学术会议(IoTSC 2026)
人工智能·分布式·科技·物联网·云计算·智慧城市·学术会议
Ronin30517 小时前
日志打印和实用 Helper 工具
数据库·sqlite·rabbitmq·文件操作·uuid生成
泡泡以安17 小时前
Scrapy分布式爬虫调度器架构设计说明
分布式·爬虫·scrapy·调度器
没有bug.的程序员18 小时前
RocketMQ 与 Kafka 深度对垒:分布式消息引擎内核、事务金融级实战与高可用演进指南
java·分布式·kafka·rocketmq·分布式消息·引擎内核·事务金融
上海锟联科技19 小时前
250MSPS DAS 在地铁监测中够用吗?——来自上海锟联科技的工程实践
分布式·科技·分布式光纤传感·das解调卡·光频域反射·das