当前位置: 首页 > news >正文

1、MQ_介绍、优缺点、类型等

MQ介绍

1. MQ概述

MQ(Message Queue):消息队列,是基础数据结构中FIFO(first in first out)的一种数据结构。一般用来解决流量削峰、应用解耦、异步处理等问题,实现高性能,高可用,可伸缩和最终一致性架构。

  • 高性能:性能好,性能高
  • 高可用:程序不会随便挂,系统的稳定性强
  • 可伸缩:增加计算机资源的时候程序的吞吐和处理能力页跟随增加
  • 最终一致性:存进来和取出去的数据是一致的

在这里插入图片描述
图上这种情况,耦合性很大,如果其中一个系统挂掉了,整个系统就停止了

下面这种情况使用了中间件,订单系统直接向中间件发起请求,这样各个系统的耦合性降低
在这里插入图片描述
小结:

  • MQ:消息队列,用于消息传递的中间件
  • 发送消息方称为生产者
  • 接收消息方称为消费者

2. MQ优缺点

  • 优点:
    • 流量削峰:避免流量高峰期导致系统挂掉,提高系统的稳定性
    • 应用解耦:降低系统之间的依赖,提高系统容错率
    • 异步请求:提速增效,提升用户体验

削峰:

  • RPS 1000:每秒处理请求的数量为1000

  • MQ可以让程序架构高内聚,低耦合
    在这里插入图片描述
    在这里插入图片描述
    解耦:
    在这里插入图片描述
    在这里插入图片描述
    异步处理:
    在这里插入图片描述
    在这里插入图片描述

  • 缺点

    • 提高了系统的复杂度,降低了系统稳定性和可用性
      • 引入了第三方技术,增加了宕机的风险
      • 如何保证系统高可用
    • 带来了数据一致性的问题
      • 各系统间的调用增加了不确定性,如何保证最终一致性
      • 怎么处理消息丢失的情况

小结:

  • 优点
    • 流量消峰:避免流量高峰时期导致系统挂掉,提高系统稳定性
    • 应用解耦:降低系统间依赖,提高系统容错性
    • 异步处理:提速增效,提高用户体验感
  • 缺点
    • 提高了系统复杂度,降低了系统稳定性和可用性
    • 带来了数据一致性问题

3.常见的MQ介绍

在这里插入图片描述
AMQP,即 Advanced Message Queuing Protocol(高级消息队列协议),是一个网络协议,是应用层协议的一个开放标准,为面向消息的中间件设计。2006年,AMQP 规范发布。

4.RabbitMQ概述

RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。

官网地址:https://www.rabbitmq.com/

  • 架构图:
    在这里插入图片描述

5.RabbitMQ名词解释

  • Producer:生产者,发送消息的程序
  • Consumer:消费者,接收消息的程序
  • Broker:接收和分发消息的应用,RabbitMQ Server 就是 Message Broker
  • Connection:生产者,消费者,Broker之间的TCP连接
  • Channel:通信连接信道,降低TCP连接开销
  • Virtual host:虚拟主机
  • Exchange:交换机,message 到达 broker 先存放到交换机
  • Queue:队列,消费者从这里获取消息
  • Binding:交换机与队列之间的虚拟连接,用于消息分发

6.RabbitMQ工作模式

从官网抄过来的:
在这里插入图片描述

相关文章:

  • 前端每日一练:三栏布局,包括 Flex 布局、浮动布局、Grid 布局以及绝对定位布局。
  • 弹性地基梁matlab有限元编程 | 双排桩支护结构 | Matlab源码 | 理论文本
  • 本地项目推送到腾讯云轻量应用服务器教程(并实现本地推送远程自动更新)
  • 设计模式:观察者模式 ⑧
  • 夏目友人帐 第六季特别篇 2017.09.27
  • Android SDK2 (实操三个小目标)
  • Android Q - 应用保活记录(展锐平台)
  • 学习JAVA的第十二天(基础)
  • 进程与线程:通过实际生活来解析计算机的基本运作单位
  • QT绑定信号槽重载
  • VS code下载与使用方法(包含远程调试)
  • anaconda, conda, conda-forge
  • SpringCloud--Sentinel基本概念介绍
  • 如何在Vue项目中应用TypeScript?
  • java 获取项目内的资源/配置文件
  • 第5章---GameplayEffect的使用
  • 算法题 — 三个数的最大乘机
  • Linux系统之部署复古游戏平台
  • RabbitMQ安装
  • 程序计数器介绍
  • 巴西总统卢拉将访华
  • 西安机场回应航站楼“水帘洞”事件:屋面排水系统被冰雹堵塞
  • 美众议院通过法案将“墨西哥湾”更名为“美国湾”
  • 波音公司计划于2027年交付新版“空军一号”飞机
  • 陕西澄城打造“中国樱桃第一县”:从黄土高原走向海外,年产值超30亿
  • 美联储主席:美联储工作方式不会受特朗普影响,从未寻求与总统会面