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).

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

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

相关文章

什么是nginx到底怎么配置,什么是网关到底怎么配置?

那使用upstream里面具体哪个服务器是怎么决定和区分的呢? AI生成 在Nginx中,使用upstream里面具体哪个服务器是通过负载均衡算法来决定的。upstream块定义了一组服务器,Nginx会根据配置的负载均衡算法来选择一个服务器来处理当前的请求。常见的负载均衡算法包括轮询(round-…

剑指offer 算法题(搜索二维矩阵)

剑指offer 第二题 去力扣里测试算法 思路一&#xff1a; 直接暴力遍历二维数组。 class Solution { public:bool searchMatrix(vector<vector<int>>& matrix, int target) {for (unsigned int i{ 0 }; i < matrix.size(); i){for (unsigned int j{ 0 };…

Shell脚本:条件语句(if、case)

目录 硬编码 硬编码的缺点 条件判断 $? 命令行语句 判断指定目录是否存在 判断指定文件是否存在 判断指定对象是否存在 表达式形式语句 判断对象是否存在 判断对象是否有权限 与、或、非 运算 与运算 或运算 非运算 比较大小 判断磁盘利用率实验步骤 字符串…

Spring Data JPA介绍与CRUD实战演练

文章目录 一、Spring Data JPA 简介二、Spring Data JPA 与 MyBatis Plus 比较设计哲学和抽象层次SQL 控制学习曲线和技术要求性能与优化综合考虑 三、SpringDataJpa实战演练1. 创建user表2. 搭建Spring Boot开发环境3. pom.xml文件内容4. application.yml文件内容5. Applicati…

Java基础之练习(2)

需求: 键盘录入一个字符串,使用程序实现在控制台遍历该字符串 package String;import java.util.Scanner;public class StringDemo5 {public static void main(String[] args) {//录入一个字符串Scanner sc new Scanner(System.in);System.out.println("请输入一个字符串…

1. 基础设计流程(以时钟分频器的设计为例)

1. 准备工作 1. 写有vcs编译命令的run_vcs.csh的shell脚本 2. 装有timescale&#xff0c;设计文件以及仿真文件的flish.f&#xff08;filelist文件&#xff0c;用于VCS直接读取&#xff09; vcs -R -full64 -fsdb -f flist.f -l test.log 2. 写代码&#xff08;重点了解代码…

2024年最新消防设施操作员(高级)题库

46.手提式干粉灭火器1~2kg近似有效喷射时间为&#xff08; &#xff09;s。 A.10 B.15 C.18 D.20 答案:A 解析:根据初级教材191页&#xff0c;手提式干粉灭火器1~2kg近似有效喷射时间为10s。 47.手提式干粉灭火器8kg近似有效喷射时间为&#xff08; &#xff09;s。 A.…

如何将办公文档压缩成rar格式文件?

压缩包格式是我们生活工作中常用到的文件格式&#xff0c;那么如何得到一个rar格式的压缩文件&#xff1f;或者说如何将文件压缩成rar格式而不是zip格式呢&#xff1f;今天我们来了解一下如何压缩为rar格式文件。 首先&#xff0c;下载并安装WinRAR&#xff0c;然后用鼠标选择需…

【第23章】Vue实战篇之文章

文章目录 前言一、搭建界面二、加载文章列表1.界面2.请求脚本3. 加载事件4. 搜索和重置5. 分页事件 三、添加文章1. 富文本编辑器1.1 安装1.2 导入组件1.3 使用1.4 样式美化 2. 页面搭建2.1 数据绑定2.2 界面 3. 图片上传3.1 数据绑定3.2 界面 4. 表单校验4.1 脚本4.2 表单 5. …

【Python】成功解决TypeError: missing 1 required positional argument

【Python】成功解决TypeError: missing 1 required positional argument 下滑即可查看博客内容 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我静心耕耘深度学习领域、真诚分享知识与智慧的小天地&#xff01;&#x1f387; &#x1f393; 博主简介&#xff1…

React的服务器端渲染(SSR)和客户端渲染(CSR)有什么区别?

React的服务器端渲染&#xff08;SSR&#xff09;和客户端渲染&#xff08;CSR&#xff09;是两种不同的页面渲染方式&#xff0c;它们各自有不同的特点和适用场景&#xff1a; 服务器端渲染&#xff08;SSR&#xff09; 页面渲染: 页面在服务器上生成&#xff0c;然后将完整的…

MySQL集合运算联结

集合的运算 & 联结&#xff08;内连接&#xff0c;左连接等等&#xff09; 假如我们有两张表&#xff0c;第一个表名为 students&#xff0c;如下所示&#xff1a; ------------------------------- | student_id | name | class_id | ------------------------------…

Redis晋级之路!!

本节pom文件 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4…

HTML下雪/烟花

文章目录 一、雪花二、烟花 一、雪花 <div id"snow"></div>body {margin: 0;background: #333; } body #snow {height: 100vh;overflow: hidden;position: relative;/*** Defaults**/--size: 1;--fallDuration: 10s;--swayDuration: 0.8s;--fallSlideSt…

复盘最近的面试

这个礼拜一直在面试&#xff0c;想着看看能否拿到不错的offer前去实习&#xff0c;从周一到周四&#xff0c;面了将近10家&#xff0c;特整理此份面经&#xff0c;希望对秋招的各位有所帮助 A公司 一面 面试官人很好&#xff0c;我回答的时候不会他会笑笑然后提醒我 自我介绍~…

数据通信与网络(三)

物理层概述&#xff1a; 物理层是网络体系结构中的最低层 它既不是指连接计算机的具体物理设备&#xff0c;也不是指负责信号传输的具体物理介质&#xff0c; 而是指在连接开放系统的物理媒体上为上一层(指数据链路层)提供传送比特流的一个物理连接。 物理层的主要功能——为…

项目中eventbus和rabbitmq配置后,不起作用

如下&#xff1a;配置了baseService层和SupplyDemand层得RabbitMQ和EventBus 但是在执行订阅事件时&#xff0c;发送得消息在base项目中没有执行&#xff0c;后来发现是虚拟机使用得不是一个&#xff0c;即上图中得EventBus下得VirtualHost&#xff0c;修改成一直就可以了

肆拾玖坊三级众筹模式玩法揭秘,白酒体验馆运作模式

发展至今&#xff0c;肆拾玖坊已积累了数百万忠实用户&#xff0c;拥有100多家分销商、5000多个新零售终端&#xff0c;覆盖全国34个省级行政区域、200余地市、1500个县区。成为中国创业界和酒行业的“现象级”企业。 今天&#xff0c;我们就来深入解析肆拾玖坊的营销模式&…

【FFmpeg】AVIOContext结构体

【FFmpeg】AVIOContext结构体 1.AVIOContext结构体的定义 参考&#xff1a; FFMPEG结构体分析&#xff1a;AVIOContext 示例工程&#xff1a; 【FFmpeg】调用ffmpeg库实现264软编 【FFmpeg】调用ffmpeg库实现264软解 【FFmpeg】调用ffmpeg库进行RTMP推流和拉流 【FFmpeg】调用…

Linux入门攻坚——26、Web Service基础知识与httpd配置-2

http协议 URL&#xff1a;Uniform Resource Locator&#xff0c;统一资源定位符 URL方案&#xff1a;scheme&#xff0c;如http://&#xff0c;https:// 服务器地址&#xff1a;IP&#xff1a;port 资源路径&#xff1a; 示例&#xff1a;http://www.test.com:80/bbs/…