什么是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的支持

相关推荐
gorgor在码农1 小时前
分布式ID方案
分布式
Aikes9022 小时前
基于redis的分布式session共享管理之销毁事件不生效问题
redis·分布式·缓存
简婷187019987754 小时前
高速路上的 “阳光哨兵”:分布式光伏监控系统守护能源高效运转
分布式·能源
钺商科技5 小时前
【6.1.2 漫画分布式事务技术选型】
分布式
帅次6 小时前
系统分析师-计算机系统-输入输出系统
人工智能·分布式·深度学习·神经网络·架构·系统架构·硬件架构
钺商科技9 小时前
【6.1.3 漫画分布式锁】
分布式
Bug退退退1231 天前
RabbitMQ 之消息积压
分布式·rabbitmq
熊猫钓鱼>_>1 天前
Hadoop 用户入门指南:驾驭大数据的力量
大数据·hadoop·分布式
文艺倾年1 天前
【八股消消乐】浅尝Kafka性能优化
分布式·性能优化·kafka
钟琛......1 天前
Redisson 的分布式锁
分布式