什么是RabbitMQ

先了解下RabbitMQ是否适合你的要求

  • 有没有你想要的语言接口?

基本上不是特别冷门的语言,RabbitMQ都能支持

RabbitMQ支持的语言列表

  • 是不是能接受额外的建设一台服务器-RabbitMQ Server?

Rabbit需要额外的架设一个服务器来让RabbitMQ处理你所有的自定义消息

  • 你的用途是什么?

RabbitMQ基本上是类似邮寄的概念,只要确保你有信箱,它就能确保一定把信送到你家。

RabbitMQ重要名词概念

主要有五大类:

  • Producer

负责将信息丢到Queue中,若有定义Exchange,则丢给Exchange决定要给谁

  • Consumer

负责接收来自Queue的消息

  • Queue

负责存放消息,具有FIFO先进先出的特性,每个Queue都会有独立的ID编号

  • Exchange

用来决定Producer给的消息要丢给哪一个Queue;

主要支持四种方式:

  1. Direct:直接丢给指定的Queue
  2. Topic:类似regular expression,设定binding规则,丢给符合的Queue
  3. Headers:透过传送资料的Header来特别指定所要的Queue
  4. fanout:一次丢给全部负责的Queue
  • Binding

和exchange搭配使用,主要告诉Exchange它负责哪些Queue

利用RabbitMQ这些特性可以做什么事情?

透过不同的组合,你可以达到不同的需求。一下为五种例子:

  • Task queues

不透过任何Exchange直接送到指定的Queue

  • Publish/Subscribe

透过exchange:fanout特性,达到订阅Queue的Consumer都可以接收到讯息

  • Routing

透过Exchange:direct特性,达到filter到不同Queue的routing消息

  • Topics

通过Exchange:topics特性,每个Queue都有属于自己的分类,通配符类型的路由

在 RabbitMQ 中,Exchange 是一个特殊类型的队列,它负责接收生产者的消息并将其路由到一个或多个队列。其中,Topic Exchange(主题交换器)是一种类型的Exchange,其特性包括:

  1. 消息路由:Topic Exchange根据消息的路由键(Routing Key)将消息路由到一个或多个队列。路由键可以使用通配符或模糊匹配来匹配。
  2. 灵活性:Topic Exchange提供了一种灵活的消息路由机制,允许将消息路由到不同的队列,以满足不同的业务需求。
  3. 可扩展性:通过使用Topic Exchange,可以将消息路由到不同的队列,从而将处理逻辑分散到不同的消费者实例或服务中,实现系统的可扩展性。
  4. 消息过滤:通过使用特定的路由键和队列的绑定规则,可以实现基于规则的消息过滤功能。例如,可以将所有来自特定用户的订单消息路由到一个特定的队列。
  5. 错误处理:如果生产者在发送消息时发生错误,消息可能会被重新放入队列中,等待其他消费者进行处理。通过使用Topic Exchange,可以确保消息被正确地路由到目标队列,以便进行错误处理和重试机制。

总之,Topic Exchange在RabbitMQ中提供了一种灵活的消息路由机制,允许将消息路由到不同的队列,以满足不同的业务需求。

  • RPC

通过AMQP所定义的properties来达成RPC的支持

相关推荐
代码漫谈20 小时前
RabbitMQ 单节点部署指南
分布式·消息队列·rabbitmq
aLTttY20 小时前
Spring Boot + Redis 实战分布式锁:从入门到精通
spring boot·redis·分布式
weixin_4196583120 小时前
RabbitMQ 应用问题
java·分布式·中间件·rabbitmq
2301_8152795221 小时前
RabbitMQ - 在微服务架构中的落地实践:消息推送 / 解耦 / 削峰填谷
微服务·架构·rabbitmq
希望永不加班21 小时前
SpringBoot 整合 RabbitMQ 入门
java·spring boot·后端·rabbitmq·java-rabbitmq
爱艺江河21 小时前
HarmonyOS智慧风控:基于分布式架构的安全与创新实践
分布式·架构·harmonyos
juniperhan21 小时前
Flink 系列第18篇:Flink 动态表、连续查询与 Changelog 机制
java·大数据·数据仓库·分布式·flink
juniperhan21 小时前
Flink 系列第19篇:深入理解 Flink SQL 的时间语义与时区处理:从原理到实战
java·大数据·数据仓库·分布式·sql·flink
珠海西格电力21 小时前
零碳园区管理系统“云-边-端”架构协同的核心价值
大数据·人工智能·分布式·微服务·架构·能源
GIS数据转换器21 小时前
延凡分布式光伏集中监控平台
人工智能·分布式·数据挖掘·数据分析·无人机·智慧城市