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

相关推荐
huaqianzkh23 分钟前
了解Hadoop:大数据处理的核心框架
大数据·hadoop·分布式
jlting1951 小时前
Kafka--关于broker的夺命连环问
分布式·kafka
菜菜-plus2 小时前
分布式,微服务,SpringCloudAlibaba,nacos,gateway,openFeign
java·分布式·微服务·nacos·gateway·springcloud·openfeign
好奇的菜鸟2 小时前
Spring Boot 启动时自动配置 RabbitMQ 交换机、队列和绑定关系
spring boot·rabbitmq
好奇的菜鸟3 小时前
RabbitMQ 通道(Channel)详解:方法使用、消息确认与拒绝
分布式·rabbitmq
黄小耶@3 小时前
python如何使用Rabbitmq
分布式·后端·python·rabbitmq
超级无敌暴龙战士(solider)3 小时前
如何保证RabbitMQ的可靠性传输
分布式·rabbitmq
小乖兽技术3 小时前
C++开发基础之使用librabbitmq库实现RabbitMQ消息队列通信
开发语言·c++·rabbitmq
简 洁 冬冬11 小时前
036 RabbitMQ消息确认 死信队列 延时队列
rabbitmq
东方巴黎~Sunsiny11 小时前
当kafka消费的数据滞后1000条时,打印告警信息
分布式·kafka·linq