RabbitMQ 相关概念

引言

什么是消息中间件

消息是指在应用间传送的数据,包含文本字符串、JSON等。消息队列中间件(MQ)指利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成。通过提供消息传递和消息排队模型,他可以在分布式环境下扩展进程间的通信。

消息队列中间件,也称为消息队列或者消息中间件,一般有两种传递模式:点对点(P2P)以及发布/订阅(Pub/Sub)模式.点对点模式是基于队列的,消息生产者发送消息到队列,消息消费者从队列中接收消息,队列的存在使得消息的异步传输成为可能。发布订阅模式定义了如何向一个内容节点发布和订阅消息,这个内容节点称为主题Topic。 消息发布者将消息发布到某个主题,而消息订阅者从主题中订阅消息。

消息中间件的作用

  • 解耦:生产者和消费者之间的依赖取决于数据的传递,消费者和生产者可以在项目迭代过程中独立变化,只要确保他们遵守同样的数据约束即可。
  • 冗余(存储):有些情况下,处理数据的过程会失败,消息中间件可以把数据进行持久化直到他们已经被完全处理。
  • 扩展性:可以增加额外的生产者和消费者副本提高消息发送以及处理的速度。
  • 削峰:在突发流量的情况下,消息中间件能够使关键组件支撑并发访问压力。
  • 可恢复性:消息中间件降低了进程间的耦合度,所以即使一个处理消息的进程挂掉,加入消息中间件的消息仍然可以在系统恢复后进行处理。
  • 顺序保证:大部分消息中间件支持一定程度上的顺序性。
  • 缓冲:在任何系统中,都会存在需要不同处理时间的元素,消息中间件通过一个缓冲层来帮助任务最高效率的执行,控制和优化数据流经过系统的速度。
  • 异步通信:允许应用把一些消息放入消息中间件,在需要的时候在慢慢处理。

相关概念

整体架构模型

在这里插入图片描述

生产者和消费者

生产者(Producer):生产者创建消息,发布到RabbitMQ中,消息一般包含2个部分:消息体和标签。消息体也称为payload,消息的标签用来表述这条消息,比如一个交换器(Exchange)的名称和一个路由键(Routing Key)。生产者把消息交由RabbitMQ,RabbitMQ之后根据标签把消息发送给相应的消费者(Consumer)。

消费者(Consumer):消费者连接到RabbitMQ服务器,并订阅到队列上。当消费者消费一条消息时,只是消费消息的payload,在消息路由的过程中,消息的标签会被丢弃

消息中间件服务节点(Broker):一个Broker可以看作一个RabbitMQ的服务节点,或者MQ服务实例。如图,展示了生产者将消息存入Broker,以及消费者从Broker中消费数据的流程。
在这里插入图片描述

队列

队列(Queue)是MQ的内部对象,用于存储消息。RabbitMQ中消息都只能存储在队列中,生产者生产消息并最终投递到队列中,消费者从队列中获取消息并消费。

多个消费者可以订阅同一个队列,这时队列中的消息会被平均分摊(Round-Robin),给多个消费者进行处理,而不是每个消费者都收到所有的消息并处理(Kafka中一个topic有多个分区,每一个分区挂载一个消费者,多个消费者共同消费一个topic)

在这里插入图片描述
RabbitMQ不支持队列层面的广播消费。

交换器、路由键、绑定

交换器

上图中消费者直接将消息投递到队列上,实际上这个在RabbitMQ中不会发生。真实情况是,生产者将消息发送到Exchange,由交换器将消息路由到一个或者多个队列中 如果路由不到或许会返回给生产者,或许直接丢弃。
在这里插入图片描述
RabbitMQ中交换器有四种类型,分别是fanout、direct、toppic、headers。

fanout
他会把所有发送到该交换器的消息路由到所有和该交换器绑定的队列中。

direct
他把消息路由到那些BindingKey和RoutingKey完全匹配的队列中。

如下所示,如果我们发送一条消息,并在发送消息的时候设置路由键为“warning”,则消息会路由到Queue1和Queue2,如果是“info”则只会路由到Queue2中。

在这里插入图片描述
topic
direct类型的交换器路由规则是完全匹配BindingKey和RoutingKey。但是这种严格的匹配方式在很多情况下不能满足业务场景需求,topic类型的交换器在匹配规则上进行了扩展,他约定:

  • RoutingKey为一个 “.” 分割的字符串(被点号分隔开的每一段独立的字符串称为一个单词),如“com.rabbitmq.client”、“java.util.concurrent”。
  • BindingKey和RoutingKey一样也是点号分隔的字符串。
  • BindingKey中可以存在两种特殊字符串 “*” 和 “#” ,用于模糊匹配,其中 “#” 用于匹配一个单词, “ * ” 用于匹配多个单词(可以是零个)。

示例:
在这里插入图片描述

  • 路由键为“com.rabbitmq.client”的消息会同时路由到queue1和queue2中。
  • 路由键为“com.hidden.client”的消息只会路由到Queue2中。
  • 路由键为“java.util.concurrent”的消息将会被丢弃或者返回给生产者(需要设置mandatory参数),因为他没有匹配任何路由键。

headers

headers类型的交换器不依赖于路由键的匹配规则来路由消息,而是根据发送的消息内容中的headers属性进行匹配。headers类型的交换器性能很差,而且很不实用。

路由键(RoutingKey)

生产者将消息发给交换器的时候,一般会指定一个RoutingKey,用来指定这个消息的路由规则,而这个RoutingKey需要和交换器类型和绑定键(BindingKey)联合使用。

绑定(Binding)

RabbitMQ中通过绑定将交换器和队列关联起来,在绑定的时候一般会指定一个BindingKey,这样MQ就知道如何正确的将消息路由到队列中了。
在这里插入图片描述

MQ运转流程

生产者发送消息
  • 连接Broker:生产者连接到Broker,建立连接(Connection),开启一个信道(Channel)。
  • 声明交换器:生产者声明一个交换器,并设置相关属性,比如交换器类型、是否持久化等。
  • 声明队列:生产者声明一个队列并设置相关属性,比如是否排他、是否持久化、是否自动删除等。
  • 绑定交换器和队列:通过路由键将交换器和队列绑定起来。
  • 生产者发送消息至Broker,交换器根据路由键查找相匹配的队列。
  • 如果找到相匹配的队列,交换器将生产者发送的消息路由到匹配的队列。
  • 如果未找到,则根据生产者配置的属性选择丢弃或者回退给生产者。
  • 关闭信道
  • 关闭连接
消费者接收消息
  • 消费者连接到Broker,建立连接,开启信道。
  • 消费者向Broker请求消费相应队列中的消息。
  • 等待Broker回应并投递相应队列中的消息,消费者接收消息。
  • 消费者确认接收到的消息。
  • MQ从队列中删除相应已经被确认的消息(所以他和Kafka不同,无法设置多个消费者组重放消费)
  • 关闭信道。
  • 关闭连接

在这里插入图片描述
如图所示,又引入了两个新的概念:Connection和Channel,无论是生产者还是消费者,都需要和Broker建立连接,这个连接就是一条TCP信道,也就是Connection。一旦TCP连接建立起来,客户端紧接着可以创建一个AMQP信道(Channel),每个信道会被指派一个唯一的ID。信道是建立在Connection之上的虚拟连接,RabbitMQ处理的每条AMQP指令都是通过信道完成的

为什么要引入信道

试想这样一个场景,一个应用程序中有很多个线程需要从MQ中消费消息或者生产消息,那么必然就需要建立很多个Connection,也就是多个TCP连接,然而对于操作系统而言,建立和销毁TCP连接是非常高昂的开销,如果遇到使用高峰,性能瓶颈也会随之显现。RabbitMQ采用类似NIO做法,选择TCP连接复用,不仅可以减少开销,同时也便于管理。

AMQP协议

RabbitMQ就是AMQP协议的Erlang语言实现版本。

AMQP协议三层结构

  • Module Layer:位于协议的最高层,主要定义了一些供客户端调用的命令,客户端可以利用这些命令实现自己的业务逻辑。例如,客户端可以使用Queue.Declare命令声明一个队列或者Basic.Consume订阅消费一个队列中的消息。
  • Session Layer:位于中间层,主要负责将客户端的命令发送给服务器,再将服务端的响应发送给客户端,主要为客户端和服务端的通信提供可靠性同步机制和错误处理
  • Transport Layer:位于最底层,主要传输二进制数据流,提供帧的处理、信道复用、错误检测和数据表示等。

AMQP生产者流转过程

示例代码:
在这里插入图片描述
当客户端与Broker建立连接的时候,会调用factory.newConnection方法,Broker会返回Connection.Start来建立连接,在连接的过程中涉及Connection.Start/.Start-OK、Connection.Tune/.Tune-OK、Connection.Open/.Open-OK这6个命令的交互。

当客户端调用connection.createChannel方法准备开启信道的时候,其包装Channel.Open命令发送给Broker,等待Channel.Open-OK命令。

当客户端发送消息的时候,需要调用channel.basicPublish方法,对应的AQMP命令为Basic.Publish,这个命令与前面涉及的命令略有不同,包含了Content Header和Content Body。Content Header 里面包含的是消息体的属性,例如,投递模式、优先级等。而Content Body包含消息体本身。

当客户端发送完消息需要关闭资源时,涉及Channel.Close/.Close-Ok、Connection.Close/.Close-Ok的命令交互,详细流转过程如下:

在这里插入图片描述

AMQP消费者流转过程

消费端代码
在这里插入图片描述
主要流程和生产者流程相似,需要注意的是,如果消费之前调用了channel.basicQos的方法来设置消费者客户端最大能“保持”的未确认的消息数,那么协议流转会涉及Basic.Qos/.Qos-OK这两个AMQP命令

消费者客户端发送Basic.Consume命令,将Channel置为接收模式。之后,Broker回执Basic.Consume-Ok以告诉消费者客户端准备好消费消息。紧接着,Broker向消费者客户端推送(Push),即Basic.Deliver命令。消费者接收到消息并正确消费之后,向Broker发送确认(Basic.ACK).

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Part 4.4 树形动态规划

树形动态规划,即在树上进行的动态规划。 因为树的递归性质,树形动态规划一般都是递归求解的。 没有上司的舞会 题目描述 某大学有 n n n 个职员,编号为 1 … n 1\ldots n 1…n。 他们之间有从属关系,也就是说他们的关系就像…

swagger手动添加cookies信息、浏览器中手动添加cookies信息

在实际项目使用中,我们可能需要把登录token放到cookies中,请求时从cookies中获取token值,以此校验用户登录信息,以下整理一下怎么在cookies中手动添加数据。 操作步骤如下: (1):F12打开调试工具&#xff…

CP AUTOSAR标准之LargeDataCOM(AUTOSAR_CP_SWS_LargeDataCOM)

1 简介和功能概述 该规范描述了AUTOSAR基础软件模块LdCom的功能、API和配置。   在AUTOSAR分层架构中,AUTOSAR LdCom模块位于RTE/SwCluC_LdComProxy和PDU路由之间,参见[1,EXP LayeredSoftwareArchitecture]。   AUTOSAR LdCom模块提供了一种替代的交互层机制。通过专注于…

Python函数与模块知识点

函数 变量作用域 匿名函数 内置函数 递归函数 思维导图 global关键字 在 Python 中,如果你在函数内部想要修改一个全局变量的值,你需要使用 global 关键字来声明这个变量。 python x 10 # 全局变量def change_x(): global x # 声明 x 是全局变量 x 20 …

算法课程笔记——单调栈单调队列

算法课程笔记——单调栈&单调队列

解锁应用新技能:Xinstall助力快速获取H5信息,轻松提升用户体验

在移动互联网时代,数据是驱动应用发展的关键。对于许多开发者来说,如何高效、准确地获取H5信息成为了一个不小的挑战。今天,我们为大家介绍一款强大的工具——Xinstall,它将帮助你轻松解决这一难题,让你的应用数据获取…

Jacob调用Windows桌面软件(Adobe系列,CAD,ABBYY FineReader 等)

参考资料 jacob调用adobe动态库https://blog.csdn.net/love_5209/article/details/19162185 python查看查看 COM 组件的 ProgID 或 CLSID 对应的字符串参数https://blog.51cto.com/u_16175517/10484354加载动态库示例https://baijiahao.baidu.com/s?id=1777971964908285215&…

在Spring Boot中使用Sa-Token实现路径拦截和特定接口放行

在Spring Boot中使用Sa-Token实现路径拦截和特定接口放行 很喜欢的一段话:别想太多,好好生活,也许日子过着过着就会有答案,努力走着走着就会有温柔的着落。 春在路上,花在枝上,所有的美好都在路上&#xff…

【STM32】使用标准库创建一个工程

创建工程 本系列文章中使用的硬件和软件版本如下: CPU型号:STM32F407ZGT6 Keil版本:V5.38.0.0 ARM编译器版本:V5.06 标准库版本:V1.8.0 1.下载标准库 官网链接:STSW-STM32065 - STM32F4 DSP和标准外…

AI金融投资:批量下载巨潮资讯基金招募说明书

打开巨潮资讯的基金招募说明书页面: http://www.cninfo.com.cn/new/fulltextSearch/full?searchkey%E5%B0%81%E9%97%AD%E5%BC%8F%E5%9F%BA%E7%A1%80%E8%AE%BE%E6%96%BD%E8%AF%81%E5%88%B8%E6%8A%95%E8%B5%84%E5%9F%BA%E9%87%91%E6%8B%9B%E5%8B%9F%E8%AF%B4%E6%98%…

智慧校园综合解决方案:提供全方位的学校管理支持

在当今数字化时代,学校管理面临着越来越多的挑战,包括学生管理、教职员工管理、校园安全等。为了应对这些挑战,智慧校园综合解决方案应运而生。智慧校园综合解决方案融入了先进的信息技术,为学校带来了一场管理与教育模式的革新。…

主流电商平台API接口【京东商品详情按关键字搜索商品按图搜索京东商品(拍立淘)获得店铺的所有商品】

主流电商平台商品接口在电商企业中的应用可以帮助企业实现信息同步、库存管理、订单处理、数据分析和营销推广等多重功能,提升运营效率、优化用户体验,进而推动业务增长。 jd API 接入说明 API地址:申请调用KEY地址 调用示例: 参数说明 通用…

jenkins中配置参数化,并在python脚本接收参数实现参数化执行

在公司内进行Monkey测试脚本集成jenkins时,因为需要指定公司内不同的app进行测试。那么可以有两种方法解决该问题,要么创建多个脚本文件,多个jenkins jobs,进行构建。要么可以在配置job时通过传参数的方式,在python脚本…

什么牌子的灯好不伤眼?带你了解什么灯对眼睛伤害最小

眼睛是人类获取信息最重要的感官器官之一,而近视则会导致视力模糊,进而影响学习效果和生活品质。因此,什么灯对眼睛伤害最小成为许多人迫切寻找的目标。本文将为各位家长解答目前许多家长选择为孩子保护视力的产品——护眼台灯。护眼台灯以其…

MAC安装idea教程

https://blog.csdn.net/qq_41810415/article/details/131649541 JDK安装 https://blog.csdn.net/dddebug/article/details/121713633 2、编辑.bash_profile文件 vim .bash_profile 进入编辑模式后 按 i 开始添加内容 结束编辑模式按 ESC 结束后保存输入 :wq! 不保存输入 :q! 检…

数据库原理(关系数据库规范化理论)——(4)

一、关系模式规范化的必要性 1.关系可能出现的问题 数据冗余大;插入异常;删除异常;更新异常; 2.关系模式应满足的基本要求 元组的每个分量必须是不可分割的数据项;数据库中的数据冗余应尽可能少;不要出…

新手教学系列-​​​​​​基础知识(SSH使用)

基础知识(SSH使用) 什么是ssh Secure Shell(安全外壳协议,简称SSH)是一种加密的网络传输协议,可在不安全的网络中为网络服务提供安全的传输环境[1]。SSH通过在网络中创建安全隧道来实现SSH客户端与服务器之间的连接[2]。虽然任何网络服务都可以通过SSH实现安全传输,SS…

电商API接口是什么意思?有什么作用?

电商API接口是电子商务领域中一种技术解决方案,它允许不同的软件系统之间进行交互和数据交换。 在电商场景下,电商API接口可以实现的功能非常丰富,例如: 商品管理:获取商品列表、商品详情、搜索商品、上下架商品等&a…

欢迎莅临ARCHE-2024,共享智慧档案盛宴!

敬邀参观!2024第三届上海国际智慧档案展览会(ARCHE-2024)将于2024年6月19-21日在上海跨国采购会展中心盛大开幕。深圳市铨顺宏科技有限公司将展示最新的智慧档案技术与解决方案,展位号H010-H011。期待您的光临,共同探索…

大数据同步方案怎么选,才能提高企业的业务效率?

大数据同步通常指的是在多个数据源或存储系统之间同步数据的过程,可以确保数据的一致性,提高数据的可用性和可靠性,同时支持数据分析和决策制定。 大数据同步的步骤通常包括: 数据识别:确定需要同步的数据类型和范围&…