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

相关推荐
元气满满的热码式2 小时前
Rabbitmq后台无法登录问题解决
分布式·rabbitmq·ruby
A尘埃2 小时前
RabbitMQ可靠和延迟队列
分布式·rabbitmq
查士丁尼·绵2 小时前
离线部署openstack 2024.1控制节点基础服务
rabbitmq·openstack·mariadb·memcache·keepalived·haproxy
Spring-wind5 小时前
【kafka】消息模型与工作原理详解
分布式·kafka
简诚11 小时前
RabbitMQ实现异步消息监听机制
rabbitmq·java-rabbitmq
TCChzp12 小时前
Kafka入门-Broker以及文件存储机制
分布式·kafka
斯普信专业组15 小时前
Kafka消费者组位移重设指南
分布式·kafka·linq
火龙谷15 小时前
【hadoop】疫情离线分析案例
大数据·hadoop·分布式
shangjg316 小时前
Eureka 心跳续约机制
java·分布式·spring cloud·eureka
bxlj_jcj17 小时前
Kafka入门:解锁核心组件,开启消息队列之旅
分布式·kafka