【MQ基本概念 MQ的工作原理】

news2024/9/22 19:34:45
一、 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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/12676.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2022年数维杯D题 极端天气问题思路指导

D题损失评估与应对策略的研究三重拉尼娜事件下的极端气候灾害 很明显D题是一个数据收集➕数据处理类型题目,这与美赛中的E题题型相似。该题所涉及的极端天气与2021年小美赛极端天气题目高度相似。因此,我们首先对大家整理了去年小美赛极端天气的相关论文…

Kubeadm搭建kubernetes集群

Kubeadm搭建kubernetes集群 环境说明 | 角色 | ip | 操作系统 |组件 | | – | – | – | | master | 192.168.226.10 |centos8 | docker,kubectl,kubeadm,kubelet | | node1 | 192.168.226.20 |centos8 |docker,kubectl&#xff…

登陆拦截案例

登陆拦截案例 登陆拦截器小案例&#xff0c;判断登陆的用户名及密码是否正确&#xff1b;&#xff1a; 1.创建一个maven项目&#xff0c;导入相关的坐标&#xff1a; <dependencies><dependency><groupId>org.springframework</groupId><artifact…

【Hack The Box】windows练习-- Blackfield

HTB 学习笔记 【Hack The Box】windows练习-- Blackfield &#x1f525;系列专栏&#xff1a;Hack The Box &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f4c6;首发时间&#xff1a;&#x1f334;2022年11月17日&#x1f334; &…

[Games 101] Lecture 10 Geometry 1 (Introduction)

Geometry 1 (Introduction) Ways to Represent Geometry 隐式 (Implicit) 几何 只告诉点满足某种约束或关系&#xff0c;并不给出实际的点&#xff0c;也就是说&#xff0c;定义 f(x,y,z)0f(x,y,z) 0 f(x,y,z)0 例如&#xff0c;定义三维空间中的点&#xff0c;满足&#…

上海亚商投顾:信创概念掀涨停潮

上海亚商投顾前言&#xff1a;无惧大盘大跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 市场情绪指数早盘低开低走&#xff0c;沪指一度跌超1%&#xff0c;失守3100点关口&#xff0c;创业板指盘中跌逾2%&#xff…

软件工程毕业设计 SSM计算机毕设项目合集【源码+论文】

文章目录前言 题目1 : 基于SSM的网上租车系统 <br /> 题目2 : 基于SSM的药品管理系统 <br /> 题目3 : 基于SSM的药源药品商城保健品购物网站 <br /> 题目4 : 基于SSM的疫情防控物业管理系统 <br /> 题目5 : 基于SSM的音乐网站 <br />前言 &…

如何通过更好的文档管理减轻小型企业的压力

如何通过更好的文档管理减轻小型企业的压力 企业如何处理企业文档在很大程度上体现了企业以目前的形式茁壮成长的能力以及在当今的市场中成长为成熟的、有竞争力的实体的能力。 具体来说&#xff0c;在小型企业中&#xff0c;许多员工都需要承担多种职责&#xff0c;每一分钟…

代码随想录58——单调栈:739每日温度、 496下一个更大元素I

文章目录1.739每日温度1.1.题目1.2.解答1.2.1.单调栈使用情况1.2.2.本题解答2. 496下一个更大元素I2.1.题目2.2.解答1.739每日温度 参考&#xff1a;代码随想录&#xff0c;739每日温度&#xff1b;力扣题目链接 1.1.题目 1.2.解答 1.2.1.单调栈使用情况 首先想到的当然是暴…

通过STM32Cube配置完成基于I2C协议的AHT20温湿度传感器的数据采集

文章目录前言一、I2C协议1、应用2、组成3、软件I2C和硬件I2C3.1软件I2C3.2硬件I2C二、通过硬件I2C协议采集AHT20的数据1、配置项目2、配置代码三、效果四、总结五、参考资料前言 硬件&#xff1a;stm32f103c8t6 核心板软件&#xff1a;STM32CubeMX 6.4.0软件&#xff1a;keil5…

java常见集合框架的区别

1.说说有哪些常见集合&#xff1f; 集合相关类和接口都在java.util中&#xff0c;主要分为3种&#xff1a;List&#xff08;列表&#xff09;、Map&#xff08;映射&#xff09;、Set(集)。 Java集合主要关系 其中Collection是集合List、Set的父接口&#xff0c;它主要有两个子…

澳大利亚博士后招聘|国立大学—太阳能电池方向

【国外博士后招聘-知识人网】澳大利亚国立大学博士后—太阳能电池方向 澳大利亚国立大学&#xff08;The Australian National University&#xff09;&#xff0c;简称ANU&#xff0c;始建于1946年&#xff0c;坐落于澳大利亚首都堪培拉&#xff0c;是公立研究型综合类大学&am…

Ernie-SimCSE对比学习在内容反作弊上应用

作者 | ANTI 导读 AI技术在不同行业和业务被广泛的应用&#xff0c;本文介绍了反作弊团队在与spammer对抗愈演愈烈的趋势下&#xff0c;不断探索前沿技术&#xff0c;将百度NLP预训练模型结合对比学习用于解决spam内容中知道提问群发推广作弊的技术方案。 本次分享&#xff0c;…

从单车智能到车路协同,均胜电子正在加快智能驾驶商业化进程

进入2022年&#xff0c;自动驾驶迈入了商业化的关键期&#xff0c;但市场分层也开始越来越明显。 一方面&#xff0c;L2级及以上智能辅助驾驶的搭载量在不断攀升&#xff0c;未来将成为量产车的标准配置。根据《高工智能汽车研究院》数据显示&#xff0c;今年1-9月前装标配搭载…

基于python的停车场管理系统的设计与实现/智能停车管理系统

摘要 车位信息是停车场供应用户必不可少的一个部分。在停车场发展的整个过程中&#xff0c;车位信息担负着最重要的角色。为满足如今日益复杂的管理需求&#xff0c;各类系统管理程序也在不断改进。本课题所设计的停车场管理系统&#xff0c;使用Django框架&#xff0c;Python语…

Linux学习-37-查看文件系统硬盘信息(df、du命令)

10.2 df用法详解&#xff1a;查看文件系统硬盘使用情况 Linux 磁盘管理好坏直接关系到整个系统的性能问题。df &#xff08;disk free&#xff09;命令&#xff0c;检查文件系统的磁盘空间占用情况&#xff0c;包括文件系统所在硬盘分区的总容量、已使用的容量、剩余容量等。 …

[附源码]Python计算机毕业设计bugbase管理系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

Div3 cf1741

Cf1741 文章目录A. Compare T-Shirt SizesB. Funny Permutation&#xff08;思维&#xff09;C. Minimize the Thickness&#xff08;&#xff09;A. Compare T-Shirt Sizes 题意: 第一行&#xff0c;输入测试样例个数n&#xff0c;接下来n行输入 &#xff0c;输入a和b代表衣服…

【自然语言处理(NLP)】基于注意力机制的英文新闻标题生成

【自然语言处理&#xff08;NLP&#xff09;】基于注意力机制的英文新闻标题生成 作者简介&#xff1a;在校大学生一枚&#xff0c;华为云享专家&#xff0c;阿里云专家博主&#xff0c;腾云先锋&#xff08;TDP&#xff09;成员&#xff0c;云曦智划项目总负责人&#xff0c;全…

SpringBoot+Vue项目宠物猫店管理系统的设计与实现

文末获取源码 开发语言&#xff1a;Java 使用框架&#xff1a;spring boot 前端技术&#xff1a;JavaScript、Vue 、css3 开发工具&#xff1a;IDEA/MyEclipse/Eclipse、Visual Studio Code 数据库&#xff1a;MySQL 5.7/8.0 数据库管理工具&#xff1a;phpstudy/Navicat JDK版…