一、 MQ 基本概念
1 MQ 概述
MQ 全称 Message Queue (消息队列),是在消息的传输过程中保存
消息的容器。多用于分布式系统之间进
行通信。
小结
MQ ,消息 队列,存储消息的中间件
分布式系统通信两种方式:直接远程调用 和 借助第三方 完成间接通信
发送方称为生产者,接收方称为消费者
2 MQ 的优势和劣势 1 、优势
优势1:应用解耦
优势2:异步提速
优势3:削峰填谷
使用了 MQ 之后,限制消费消息的速度为 1000 ,这样一来,高峰期产
生的数据势必会被积压在 MQ 中,高峰
就被 “ 削 ” 掉了,但是因为消息积压,在高峰期过后的一段时间内,消费消息
的速度还是会维持在 1000 ,直
到消费完积压的消息,这就叫做 “ 填谷 ” 。
使用 MQ 后,可以提高系统稳定性。
小结
⚫ 应用解耦:提高系统容错性和可维护性
⚫ 异步提速:提升用户体验和系统吞吐量
⚫ 削峰填谷:提高系统稳定性
2 、劣势
系统可用性降低
系统复杂度提高
一致性问题
⚫ 系统可用性降低
系统引入的外部依赖越多,系统稳定性越差。一旦 MQ 宕机,就会
对业务造成影响。如何保证 MQ 的高可用?
⚫ 系统复杂度提高
MQ 的加入大大增加了系统的复杂度,以前系统间是同步的远程调
用,现在是通过 MQ 进行异步调用。如何
保证消息没有被重复消费?怎么处理消息丢失情况?那么保证消息
传递的顺序性?
⚫ 一致性问题
A 系统处理完业务,通过 MQ 给 B 、 C 、 D 三个系统发消息数据,如
果 B 系统、 C 系统处理成功, D 系统处理
失败。如何保证消息数据处理的一致性?
小结
既然 MQ 有优势也有劣势,那么使用 MQ 需要满足什么条件呢?
① 生产者不需要从消费者处获得反馈。引入消息队列之前的直接调用,其
接口的返回值应该为空,这才让明
明下层的动作还没做,上层却当成动作做完了继续往后走,即所谓异步
成为了可能。
② 容许短暂的不一致性。
③ 确实是用了有效果。即解耦、提速、削峰这些方面的收益,超过加入
MQ ,管理 MQ 这些成本。
3 、常见的 MQ 产品
目前业界有很多的 MQ 产品,例如 RabbitMQ 、 RocketMQ 、
ActiveMQ 、 Kafka 、 ZeroMQ 、 MetaMq 等,
也有直接使用 Redis 充当消息队列的案例,而这些消息队列产品,各有侧
重,在实际选型时,需要结合自身需
求及 MQ 产品特征,综合考虑。
由于 RabbitMQ 综合能力强劲,所以接下来的课程中,我们将主要学习
RabbitMQ 。
4 RabbitMQ 简介
AMQP ,即 Advanced Message Queuing Protocol (高级消息队列协
议),是一个网络协议,是应用层协议
的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息
中间件可传递消息,并不受客户端 / 中
间件不同产品,不同的开发语言等条件的限制。 2006 年, AMQP 规范发
布。类比 HTTP 。
2007 年, Rabbit 技术公司基于 AMQP 标准开发的 RabbitMQ 1.0 发
布。 RabbitMQ 采用 Erlang 语言开发。
Erlang 语言由 Ericson 设计,专门为开发高并发和分布式系统的一种语
言,在电信领域使用广泛。
RabbitMQ 基础架构如下图:
RabbitMQ 中的相关概念:
Broker :接收和分发消息的应用, RabbitMQ Server 就是 Message
Broker
Virtual host :出于多租户和安全因素设计的,把 AMQP 的基本组件
划分到一个虚拟的分组中,类似于网
络中的 namespace 概念。当多个不同的用户使用同一个 RabbitMQ
server 提供的服务时,可以划分出多
个 vhost ,每个用户在自己的 vhost 创建 exchange / queue 等
Connection : publisher / consumer 和 broker 之间的 TCP 连接
Channel :如果每一次访问 RabbitMQ 都建立一个 Connection ,在消
息量大的时候建立 TCP Connection
的开销将是巨大的,效率也较低。 Channel 是在 connection 内部建立
的逻辑连接,如果应用程序支持多线
程,通常每个 thread 创建单独的 channel 进行通讯, AMQP method
包含了 channel id 帮助客户端和
message broker 识别 channel ,所以 channel 之间是完全隔离的。
Channel 作为轻量级的 Connection
极大减少了操作系统建立 TCP connection 的开销
Exchange : message 到达 broker 的第一站,根据分发规则,匹配查
询表中的 routing key ,分发消息到
queue 中去。常用的类型有: direct (point-to-point), topic (publish
subscribe) and fanout (multicast)
Queue :消息最终被送到这里等待 consumer 取走
Binding : exchange 和 queue 之间的虚拟连接, binding 中可以包含
routing key 。 Binding 信息被保存
到 exchange 中的查询表中,用于 message 的分发依据
RabbitMQ 提供了 6 种工作模式: 简单模式
work queues
Publish/Subscribe 发布与订阅模式
Routing 路由模式
Topics 主题模式
RPC 远程调用模式(远程调用,不太算 MQ ;暂不作介绍)。
官网对应模式介绍: https://www.rabbitmq.com/getstarted.html
5 JMS
⚫ JMS 即 Java 消息服务( JavaMessage Service )应用程序接口,是一个
Java 平台中关于面向消息中间件
的 API
⚫ JMS 是 JavaEE 规范中的一种,类比 JDBC
⚫ 很多消息中间件都实现了 JMS 规范,例如: ActiveMQ 。 RabbitMQ 官方
没有提供 JMS 的实现包,但是开
源社区有
小结 :
1. RabbitMQ 是基于 AMQP 协议使用 Erlang 语言开发的一款消息队列产
品。
2. RabbitMQ 提供了 6 种工作模式,我们学习 5 种。这是今天的重点。
3. AMQP 是协议,类比 HTTP 。
4. JMS 是 API 规范接口,类比 JDBC 。
6 RabbiMQ 安装与卸载
安装参考 :
https://blog.csdn.net/tirster/article/details/12193898
卸载参考 :
https://www.moguit.cn/info/992

【MQ基本概念 MQ的工作原理】相关推荐

  1. 桂隆阀门水力控制阀的概念-种类及工作原理

    桂隆阀门水力控制阀知识:1.水力控制阀的概念:水力控制阀就是水压控制的阀门,它由一个主阀及其附设的导管﹑导阀﹑针阀﹑球阀和压力表等组成. 2.上海阀门厂水力控制阀的种类:根据使用目的﹑功能及场所的不同 ...

  2. 浅析堡垒机概念及工作原理(转)

    摘 要:在信息化社会,企事业单位业务对信息系统高度依赖,而信息系统维护人员往往拥有系统最高管理权限,其操作行为必须得到有效监管与审计.作为运维操作审计最佳解决方案的堡垒机通常会给人一种神秘莫测的感觉, ...

  3. 消息队列+RabbitMq工作原理

    目录 1.消息队列 2.应用场景 2.1 异步处理 2.2 应用解耦 2.3流量削锋 2.4 日志处理 3.RabbitMQ介绍 4.RabbitMQ工作原理 1.消息队列 消息即是信息的载体 消息队 ...

  4. 【Appium】Appium工作原理

    参考:http://www.cnblogs.com/zhjsll/p/5698878.html 原作者写的很好,所以直接放在这里. 一.什么是Appium Appium是一个开源.跨平台的测试框架,可 ...

  5. OSPF路由协议概念及工作原理

    随着Internet技术在全球范围内的飞速发展,IP网络作为一种最有前景的网络技术,受到了人们的普遍关注.而作为IP网络生存.运作.组织的核心--IP路由技术提供了解决IP网络动态可变性.实时性.Qo ...

  6. 轻松认识HTTP协议的概念和工作原理

    轻松认识HTTP协议的概念和工作原理 当我们想浏览一个网站的时候,只要在浏览器的地址栏里输入网站的地址就可以了,例如:www.microsoft.com,但是在浏览器的地址栏里面出现的却是:http: ...

  7. 区块链的基本概念和工作原理

    区块链的基本概念和工作原理 1.基本概念 区块链是分布式数据存储.点对点传输.共识机制.加密算法等计算机技术的新型应用模式.所谓共识机制是区块链系统中实现不同节点之间建立信任.获取权益的数学算法. 区 ...

  8. 三极管概念工作原理及其应用

    三极管在我们数字电路和模拟电路中都有大量的应用,在我们开发板上也用了多个三极管.在我们板子上的 LED 小灯部分,就有这个三极管的应用了,图 3-5 的 LED 电路中的 Q16就是一个 PNP 型的 ...

  9. SSL 与 数字证书 的基本概念和工作原理

    SSL是让人头大的东西,看起来很复杂,我学过信息安全课,但是对SSL仍然是模糊一片.对于数字证书也是一知半解,从来没有去认真研究过.只知道个大概,"反正就是对称加密和非对称加密", ...

最新文章

  1. 快手Java一面,二面社招合并面经分享
  2. “32 位应用已死!”
  3. unity, access standard shared emission by script
  4. 电商企业纷纷结缘信息化 管理系统如何给力?
  5. Git,Github和Gitlab简介和基本使用
  6. mysql聚合函数count用法_MySQL中聚合函数count的使用和性能优化技巧
  7. esp32 rtc 时钟设置不对_「STM32」实时时钟(RTC)实验
  8. 【转】HTTP协议中PUT和POST使用区别
  9. Android代码导出数据库,导入/导出到android sqlite数据库
  10. [导入]vs2005视频教程 之 编译程序集和发布网站 [视频]
  11. 牛客寒假算法基础训练营3
  12. 2020-11-17 一道有趣的求极限问题
  13. 湖北工业大学计算机导论考试试题,湖北工业大学计算机二级考试时间
  14. win下使用curl
  15. 深入浅出DockerPDF
  16. 通过scheme协议启动app
  17. unity简单实现融合树动画
  18. 集线器Hub、交换机Switch 和 路由器Router 的区别
  19. iPhone数据线连接电脑成为电脑USB摄像头
  20. 天美服务器未响应,王者荣耀服务器上热搜,无数玩家遭遇掉线烦恼,天美该怎么办?...

热门文章

  1. 首届“天网杯”网络安全大赛启动 | 赛宁网安提供全面技术支撑
  2. 用好collections模块,对李白诗集进行字频统计
  3. 第十一届蓝桥杯电子类国赛总结回顾
  4. Mesosphere公司正式更名为D2IQ,关注点转向Kubernetes与云原生领域
  5. 实验记录 | mutect问题详解:No tribble type was provided on the command line and the type of the file?
  6. JAVA解析pdf文件
  7. Java1-4章复习
  8. 一刀工具箱 - 动物叫声
  9. 恒玄BES调试笔记-BES2500死机重启分析手段
  10. linux超频软件,GreenWithEnvy 0.11 发布,Linux上NVIDIA GPU的超频工具