一、MQ的基本概念

1、MQ的概述

2、MQ的优势

应用解耦

异步提速

削峰填谷

3、MQ的劣势

系统可用性降低

系统复杂度提高

一致性问题

4、MQ的使用条件

5、常见的MQ的产品

二、什么是RabbitMQ

1、RabbitMQ概念

Broker(服务端)

Virtual host(虚拟机)

Connection(连接)

Channel(管道)

Exchange(交换机)

Queue(队列)

Binding()

2、AMQP

3、JMS

三、RabbitMQ的工作模式(简述)

1、简单模式

2、work queues

3、Publish/Subscribe 发布与订阅模式

4、Routing 路由模式

5、Topics 主题模式

6、RPC 远程调用模式(远程调用,不太算MQ;暂不作介绍)


一、MQ的基本概念

1、MQ的概述

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

在没有RabbitMQ之前,我们通常是使用远程调用的方式建立两者的通信

有了RabbitMQ之后,两者之间的结构如下:

2、MQ的优势

  1. 应用解耦:提高系统容错性和可维护性
  2. 异步提速:提升用户体验和系统吞吐量
  3. 削峰填谷:提高系统稳定性
  • 应用解耦

系统的耦合性越高,容错性就越低,可维护性就越低。

订单系统各个子系统之间加了MQ减少了订单系统与各个系统的耦合

使用MQ使得应用间解耦,提升容错性和可维护性

  • 异步提速

没有MQ的时候,项目的逻辑架构如下所示:

一个下单操作耗时:20 + 300 + 300 + 300 = 920ms

用户点击完下单按钮后,需要等待920ms才能得到下单响应,太慢! 

引入MQ之后:

用户点击完下单按钮后,只需等待25ms就能得到下单响应 (20 + 5 = 25ms)。

提升用户体验和系统吞吐量(单位时间内处理请求的数目) 

注:系统可以先给用户做出反应,后续的未执行的事情交由MQ慢慢执行!

  • 削峰填谷

如果没有MQ,请求的数量瞬间增加,可能会导致A系统直接“崩掉!”

使用了MQ 之后,限制消费消息的速度为1000(假设),这样一来,高峰期产生的数据势必会被积压在MQ 中,高峰就被“削”掉了,但是因为消息积压,在高峰期过后的一段时间内,消费消息的速度还是会维持在1000,直到消费完积压的消息,这就叫做“填谷”。

相当于一个缓冲区,让数据慢慢交给系统!

使用MQ后,可以提高系统稳定性 

3、MQ的劣势

系统可用性降低

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

系统复杂度提高

MQ 的加入大大增加了系统的复杂度,以前系统间是同步的远程调用,现在是通过MQ进行异步调用

如何保证消息没有被重复消费?

怎么处理消息丢失情况?

那么保证消息传递的顺序性?

一致性问题

A 系统处理完业务,通过MQ 给B、C、D三个系统发消息数据,如果 B 系统、C 系统处理成功,D 系统处理失败。如何保证消息数据处理的一致性?

上述提到的问题都是在使用MQ的过程中遇到的!解决它们是用好MQ的前提!该内容将会在后续的章节进行讲解。

4、MQ的使用条件

① 生产者不需要从消费者处获得反馈。引入消息队列之前的直接调用,其接口的返回值应该为空,这才让明明下层的动作还没做,上层却当成动作做完了继续往后走,即所谓异步成为了可能。(单向的数据流动)

容许短暂的不一致性

③ 确实是用了有效果。即解耦、提速、削峰这些方面的收益,超过加入MQ,管理MQ这些成本。

5、常见的MQ的产品

二、什么是RabbitMQ

1、RabbitMQ概念

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

Broker(服务端)

接收和分发消息的应用,RabbitMQ Server就是 Message Broker

Producer与Consumer都是客户端,Broker是服务端

Virtual host(虚拟机)

出于多租户和安全因素设计的,把AMQP 的基本组件划分到一个虚拟的分组中,类似于网 络中的 namespace 概念。当多个不同的用户使用同一个 RabbitMQ server 提供的服务时,可以划分出多 个vhost,每个用户在自己的 vhost 创建 exchange/queue 等(逻辑区分,互不影响

Connection(连接)

publisher/consumer 和 broker 之间的 TCP 连接

Channel(管道)

如果每一次访问 RabbitMQ 都建立一个 Connection,在消息量大的时候建立 TCP Connection 的开销将是巨大的,效率也较低。

Channel相当于是一个小的Connection

Channel 是在 connection 内部建立的逻辑连接,如果应用程序支持多线程,通常每个thread创建单独的 channel 进行通讯,AMQP method 包含了channel id 帮助客户端和 message broker 识别 channel,所以 channel 之间是完全隔离的。Channel 作为轻量级的 Connection 极大减少了操作系统建立 TCP connection 的开销。

Exchange(交换机)

message 到达 broker 的第一站,根据分发规则匹配查询表中的 routing key,分发消息到 queue 中去。常用的类型有:direct、 topicfanout、headers(少见)

Queue(队列)

消息最终被送到这里等待 consumer 取走

Binding()

exchange 和 queue 之间的虚拟连接,binding 中可以包含 routing key。Binding 信息被保存到 exchange 中的查询表中,用于message 的分发依据。

2、AMQP

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

简单的来说,AMQP是一种协议。

类比于HTTP,在HTTP中,我们设置了请求与响应的数据格式,只要遵循这种数据格式,我们就可以使用HTTP来完成通信。

同理,只要遵循消息队列的协议我们就可以做出一个消息队列的产品,来完成消息的传输

3、JMS

JMS 即 Java 消息服务(JavaMessage Service)应用程序接口,是一个 Java 平台中关于面向消息中间件的API

JMS 是 JavaEE 规范中的一种,类比JDBC

很多消息中间件都实现了JMS规范,例如:ActiveMQ。RabbitMQ 官方没有提供 JMS 的实现包,但是开源社区有。

三、RabbitMQ的工作模式(简述)

在RabbitMQ的官网有介绍,罗列了如下4中模式,其中比较常见的有Routing 路由模式Topics 主题模式

官网的连接如下所示

RabbitMQ Tutorials — RabbitMQhttps://www.rabbitmq.com/getstarted.html

1、简单模式

2、work queues

3、Publish/Subscribe 发布与订阅模式

4、Routing 路由模式

5、Topics 主题模式

6、RPC 远程调用模式(远程调用,不太算MQ;暂不作介绍)

具体的每一种模式的实现,在后续的章节都会提到!!!

RabbitMQ入门教程 1相关推荐

  1. RabbitMQ入门教程(安装,管理插件,Publisher/Consumer/交换机/路由/队列/绑定关系,及如何保证100%投递等)

    RabbitMQ入门教程(安装,管理插件,Publisher/Consumer/交换机/路由/队列/绑定关系,及如何保证100%投递等) 1. RabbitMQ简介及AMQP协议 开源的消息代理和队列 ...

  2. RabbitMQ 入门教程(PHP版) 第三部分:发布/订阅(Publish/Subscribe)

    发布/订阅 在上篇第二部分教程中,我们搭建了一个工作队列.每个任务之分发给一个工作者(worker).在本篇教程中,我们要做的之前完全不一样--分发一个消息给多个消费者(consumers).这种模式 ...

  3. 干货!消息队列RabbitMQ入门教程

    ​写在前面:全文12000多字,从为什么需要用消息队列,到rabbitMQ安装使用,如何使用JavaAPI生产消费消息,以及使用消息队列带来的一些常见问题.绝对很适合新手入门学习. 为什么需要消息队列 ...

  4. RabbitMQ入门教程——.NET客户端使用

    众所周知RabbitMQ使用的是AMQP协议.我们知道AMQP是一种网络协议,能够支持符合要求的客户端应用和消息中间件代理之间进行通信. 其中消息代理扮演的角色就是从生产者那儿接受消息,并根据既定的路 ...

  5. RabbitMQ入门教程——发布/订阅

    什么是发布订阅 发布订阅是一种设计模式定义了一对多的依赖关系,让多个订阅者对象同时监听某一个主题对象.这个主题对象在自身状态变化时,会通知所有的订阅者对象,使他们能够自动更新自己的状态. 为了描述这种 ...

  6. php写入rabbit速度,RabbitMQ 入门教程(PHP) 实现延迟功能

    php 使用rabbitmq-delayed-message-exchange插件实现延迟功能 1.安装 3.6.x下载地址 3.7.x下载地址 下载后解压,并将其拷贝至(使用Linux Debian ...

  7. RabbitMQ入门教程

    摘要: 使用RabbitMQ的消息队列,可以有效提高系统的峰值处理能力. RabbitMQ简介 RabbitMQ是消息代理(Message Broker),它支持多种异步消息处理方式,最常见的有: W ...

  8. RabbitMQ入门教程(十一):消息属性Properties

    分享一个朋友的人工智能教程.比较通俗易懂,风趣幽默,感兴趣的朋友可以去看看. 简介 发送消息可以为消息指定一些参数 Delivery mode: 是否持久化,1 - Non-persistent,2 ...

  9. RabbitMQ入门教程(四):工作队列(Work Queues)

    分享一个朋友的人工智能教程.比较通俗易懂,风趣幽默,感兴趣的朋友可以去看看. 工作队列 使用工作队列实现任务分发的功能,一个队列的优点就是很容易处理并行化的工作能力,但是如果我们积累了大量的工作,我们 ...

最新文章

  1. Error: Discrete value supplied to continuous scale
  2. 卡巴斯基授权许可文件_安全许可证的申请流程有哪些?
  3. Java并发编程(三)volatile域
  4. mybatis 批量将list数据插入到数据库
  5. HDU3509(构造矩阵)
  6. Active Record 数据库迁移总结
  7. 安装HCL模拟器遇到的问题标题文章
  8. linux下cabal安装教程,Centos 7 安装shellcheck
  9. 腾讯云开发者大会 | 腾讯云大学首次与业界顶尖厂商合作的线上学习专区重磅发布...
  10. Futter基础第18篇: 实现调用原生时间选择器、日期选择器、时间戳、Future异步
  11. Rem实现自适应初体验
  12. 20191129每日一句
  13. 写给喜欢单片机的初学者
  14. 企业微信第三方应用开发--回调配置
  15. 微信小程序游戏开发│智力测试游戏——button版
  16. c语言 for each循环,C#中foreach循环对比for循环的优势和劣势
  17. 关于远程连接挂载磁盘的理解(.bat文件、批处理)
  18. 【两所985大学】计算机/软件学院被合并到信息学部/院!
  19. 基于HVS 的结构相似性的视频质量评价
  20. 一菜鸟写的家庭理财软件的一些需求

热门文章

  1. C语言求出100-1000内的所有水仙花数
  2. 这样的校园,诱人而深邃
  3. 远程登陆服务器----ssh远程传输文件
  4. windows下 c++多进程
  5. C语言的文件操作(文件指针、文件缓冲区、文件的打开、读写操作)
  6. js数组分割(场景-分页数据)
  7. 如何取消苹果自动续费?手把手教你关闭自动续费全步骤
  8. 警方为您送上网购安全大红包
  9. 桌面计算机休眠快捷键,快捷休眠只一键 Win7桌面建立睡眠按钮
  10. 技术面试问题汇总第005篇:猎豹移动反病毒工程师part5