RabbitMQ概述与工作模式

本文介绍了消息队列(MQ)的概念及其优势与劣势,并详细解析了RabbitMQ的工作原理及应用场景。包括RabbitMQ的关键组件如Broker、Virtualhost、Connection、Channel、Exchange、Queue和Binding,同时概述了六种典型的工作模式。
摘要由CSDN通过智能技术生成

1.什么是MQ

MQ全称 Message Queue消息队列),是在消息的传输过程中保存消息的容器。多用于分布式系统之间进行通信。

1.1 MQ的优势

1.应用解耦:系统的耦合性越高,容错性就越低,可维护性就越低。使用 MQ 使得应用间解耦,提升容错性和可维护性。

2.异步提速:提升用户体验和系统吞吐量(单位时间内处理请求的数目)。

3.削峰填谷:提高系统稳定性。

1.2 MQ的劣势

1.系统可用性降低

系统引入的外部依赖越多,系统稳定性越差。一旦 MQ 宕机,就会对业务造成影响。如何保证MQ的高可用?

2.系统复杂度提高

MQ 的加入大大增加了系统的复杂度,以前系统间是同步的远程调用,现在是通过 MQ 进行异步调用。如何保证消息不被丢失等情况

1.3 RabbitMQ简介

AMQP Advanced Message Queuing Protocol(高级消息队列协议),是一个网络协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。2006年,AMQP 规范发布。类比HTTP

2007年,Rabbit 技术公司基于 AMQP 标准开发的 RabbitMQ 1.0 发布。RabbitMQ 采用 Erlang 语言开发。Erlang 语言由 Ericson 设计,专门为开发高并发和分布式系统的一种语言,在电信领域使用广泛。RabbitMQ 相关概念:

1. Broker 接收和分发消息的应用,RabbitMQ Server就是 Message Broker
2. Virtual host 出于多租户和安全因素设计的,把 AMQP 的基本组件划分到一个虚拟的分组中,类似于网络中的 namespace 概念。当多个不同的用户使用同一个 RabbitMQ server 提供的服务时,可以划分出多个vhost,每个用户在自己的 vhost 创建 exchange/queue 等
3. Connection publisher/consumer 和 broker 之间的 TCP 连接
4. Channel 如果每一次访问 RabbitMQ 都建立一个 Connection,在消息量大的时候建立 TCP Connection的开销将是巨大的,效率也较低。Channel 是在 connection 内部建立的逻辑连接,如果应用程序支持多线程,通常每个thread创建单独的 channel 进行通讯,AMQP method 包含了channel id 帮助客户端和message broker 识别 channel,所以 channel 之间是完全隔离的。Channel 作为轻量级的 Connection 极大减少了操作系统建立 TCP connection 的开销
5. Exchange message 到达 broker 的第一站,根据分发规则,匹配查询表中的 routing key,分发消息到queue 中去。常用的类型有:direct (point-to-point), topic (publish-subscribe) and fanout (multicast)
6. Queue 消息最终被送到这里等待 consumer 取走
7. Binding exchange 和 queue 之间的虚拟连接,binding 中可以包含 routing key。Binding 信息被保存到 exchange 中的查询表中,用于 message 的分发依据

2.RabbitMQ 的 6 种工作模式

简单模式work queuesPublish/Subscribe 发布与订阅模式Routing 路由模式Topics 主题模式RPC 远程调用模式(远程调用,不太算 MQ;暂不作介绍)。官网对应模式介绍:https://www.rabbitmq.com/getstarted.html

总结

前2种无交换机模式,就是生产者往队列里发消息,消费者监听队列

  1. 简单模式 :生产者往队列里发消息,消费者监听队列的消息
  2. work queues:生产者往队列里发消息,多个消费者监听一个队列的消息,因为预取机制(prefetch)消息默认是平均分配,可以配置prefetch=1,这样就会按消费者的消费能力消费,消费的快自然就消费的多

后3种带交换机模式,生产者往队列里发消息,消费者除了监听队列,还需要声明队列和交换机的绑定关系,是哪种交换机,以及有没有通过路由键绑定,如果有,是哪种路由键

  1. Publish/Subscribe 发布与订阅模式:交换机类型是fanout,生产者往交换机里发消息(不需要声明路由键),消费者要声明监听队列以及队列和交换机的绑定关系,交换机收到生产者消息后路由给与之绑定的队列。binding=exchange+queue
  2. Routing 路由模式:交换机类型是direct,生产者往交换机里发消息(需要声明路由键),消费者要声明监听队列以及绑定关系(是通过哪个路由键绑定监听队列和交换机),交换机收到生产者消息后根据路由键路由给与之绑定的队列。binding=exchange+queue with routing key(type)
  3. Topics 主题模式:交换机类型是topic,生产者往交换机里发消息(需要声明通配符形式的路由键),消费者要声明监听队列以及绑定关系(是通过哪个通配符路由键绑定监听队列和交换机), 交换机收到生产者消息后根据通配符型路由键路由给与之绑定的队列。binding=exchange+queue with routing key(typea.#  *.typeb)

通配符规则:

#:匹配一个或多个词

*:匹配不多不少恰好1个词

交换机的作用是什么?

  • 接收生产者(publisher)发送的消息
  • 将消息按照规则路由到与之绑定的队列
  • 不能缓存消息,路由失败,消息丢失
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值