RabbitMQ知识总结(工作模式)

文章收录在网站:http://hardyfish.top/

文章收录在网站:http://hardyfish.top/

文章收录在网站:http://hardyfish.top/

文章收录在网站:http://hardyfish.top/

工作模式

简单模式

一个生产者对应一个消费者,通过队列进行消息传递。

该模式使用 direct 交换机,direct 交换机是 RabbitMQ 默认交换机。

工作队列模式

与简单模式相比,工作队列模式(Work Queue)多了一些消费者。

该模式也使用 direct 交换机,应用于处理消息较多的情况。

特点如下:

  • 一个队列对应多个消费者。
  • 一条消息只会被一个消费者消费。
  • 消息队列默认采用 轮询 的方式将消息平均发送给消费者。

发布订阅模式

在开发过程中,有一些消息需要不同消费者进行不同的处理,如电商网站的同一条促销信息需要短信发送、邮件发送、站内信发送等。

此时可以使用发布订阅模式(Publish/Subscribe)。

特点如下:

  • 生产者将消息发送给交换机,交换机将消息转发到绑定此交换机的 每个队列 中。

  • 工作队列模式的交换机只能将消息发送给一个队列,发布订阅模式的交换机能将消息发送给多个队列。

  • 发布订阅模式使用 fanout 交换机。

路由模式

使用发布订阅模式时,所有消息都会发送到绑定的队列中,但很多时候,不是所有消息都无差别的发布到所有队列中。

  • 比如电商网站的促销活动,618大促可能会发布到所有队列。

  • 而一些小的促销活动为了节约成本,只发布到站内信队列。

  • 此时需要使用 路由模式 (Routing)完成这一需求。

特点如下:

  • 每个队列绑定路由关键字 RoutingKey。

  • 生产者将带有 RoutingKey 的消息发送给交换机,交换机根据 RoutingKey 转发到指定队列。

  • 路由模式使用 direct 交换机。

  • 能按照路由键将消息发送给指定队列。

通配符模式

通配符模式(Topics)是在路由模式的基础上,给队列绑定带通配符的路由关键字,只要消息的 RoutingKey 能实现通配符匹配,就会将消息转发到该队列。

  • 通配符模式比路由模式更灵活,通配符模式使用 topic 交换机。

  • 能按照通配符规则将消息发送给指定队列。

通配符规则如下:

  • 队列设置 RoutingKey 时,# 可以匹配任意多个单词,* 可以匹配任意一个单词。

  • 消息设置 RoutingKey 时,RoutingKey 由多个单词构成,中间以 . 分割。

相关推荐
KmSH8umpK24 分钟前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
KmSH8umpK3 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
_F_y8 小时前
仿RabbitMQ实现消息队列-服务端核心模块实现(4)
分布式·rabbitmq
Albert Edison11 小时前
【RabbitMQ】发布确认模式(使用案例)
分布式·rabbitmq·ruby
EXnf1SbYK13 小时前
Redis分布式锁进阶第十二篇:全系列终极兜底复盘 + 锁架构巡检落地 + 线上零事故收尾方案
redis·分布式·架构
EXnf1SbYK13 小时前
Redis分布式锁进阶第八篇:锁超时乱序深度踩坑 + 看门狗失效真实溯源 + 业务长耗时标准化兜底方案
数据库·redis·分布式
EXnf1SbYK13 小时前
Redis分布式锁进阶第十一篇
数据库·redis·分布式
biyezuopinvip14 小时前
分布式风电场低电压穿越故障建模与仿真
分布式·matlab·毕业设计·毕业论文·分布式风电场·低电压穿越故障·建模与仿真
苍煜14 小时前
SpringBoot单体应用到分布式下的数据库锁、事务、Redis事务、分布式锁、分布式事务协调
数据库·spring boot·分布式
fengxin_rou14 小时前
黑马点评项目万字总结:从redis基础到实战应用详解
java·开发语言·分布式·后端·黑马点评