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.rhkb.cn/news/353465.html

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

相关文章

基于STM32和人工智能的智能四轴飞行器系统

目录 引言环境准备智能四轴飞行器系统基础代码实现:实现智能四轴飞行器系统 4.1 数据采集模块4.2 数据处理与分析4.3 控制系统4.4 用户界面与数据可视化应用场景:智能飞行器管理与优化问题解决方案与优化收尾与总结 1. 引言 随着无人机技术的发展&…

8.华为两台交换机的三种连接方式access 、trunk、undo portswitch

目的:两台三层交换机的三种连接方式 1.access 2.trunk 3.undo portswitch 模拟机不支持此配置,实体机支持 第一种access CE1配置 [~HUAWEI]vlan batch 10 [~HUAWEI]int Vlanif 10 [~HUAWEI-Vlanif10]ip add 10.10.10.1 24 [~HUAWEI]int g1/0/0 [~HUAWE…

Go语言RPC开发深度指南:net/rpc包的实战技巧和优化策略

Go语言RPC开发深度指南:net/rpc包的实战技巧和优化策略 概览理解net/rpc的核心概念RPC的基本原理net/rpc的工作模式关键特性 快速开始准备RPC服务和客户端的基础环境构建一个基础的RPC服务端构建一个基础的RPC客户端 开发一个实际的RPC服务设计服务接口实现服务客户…

男士内裤哪个品牌质量好?国内质量好的男士内裤推荐

今天想和大家分享一个虽不起眼但至关重要的时尚单品——男士内裤。它可能不像外套或鞋子那样引人注目,但却承载着男士们日常的舒适与健康。选择一款合适的男士内裤,不仅能提升穿着体验,更是展现个人品味和生活态度的关键。以下是一些选择内裤…

JS读取目录下的所有图片/require动态加载图片/文字高亮

<template class"aa"><div class"demo-image__lazy container"><div class"head"><div class"left-bar"><div><span>综合</span></div><div><span>定位</span><…

睡眠脑电 | 多导睡眠图技术

摘要 多导睡眠图(PSG)一词由Holland等人于1974年提出&#xff0c;用于描述在睡眠期间同时记录、分析和解释多个生理特征。PSG是诊断睡眠障碍患者和增进我们对正常睡眠认识的重要工具。这是一个复杂的过程&#xff0c;应由训练有素的技术人员执行。本文回顾了多导睡眠图(PSG)的…

享元和代理模式

文章目录 享元模式1.引出享元模式1.展示网站项目需求2.传统方案解决3.问题分析 2.享元模式1.基本介绍2.原理类图3.外部状态和内部状态4.类图5.代码实现1.AbsWebSite.java 抽象的网站2.ConcreteWebSite.java 具体的网站&#xff0c;type属性是内部状态3.WebSiteFactory.java 网站…

JavaScript和promise——0_1 promise

文章目录 是什么&#xff1f;未来值回调和未来值在回调环境下这么和未来值交互&#xff1f;群居的未来值其他的解决方案 这样写可以实现目标效果。可是&#xff0c;这样写优雅吗&#xff1f; 英雄登场关键词&#xff1a;then关键词&#xff1a;回调 为什么promise不需要start函…

vue修改node_modules打补丁步骤和注意事项_node_modules 打补丁

1、vue-pdf问题解决及patch-package简介&#xff1a;https://www.jianshu.com/p/d1887e02f8d6 2、使用“黑魔法”优雅的修改第三方依赖包&#xff1a;https://zhuanlan.zhihu.com/p/412753695 3、使用patch-package定制node_modules中的依赖包&#xff1a;https://blog.csdn.…

自动驾驶仿真:Carsim转向传动比设置

文章目录 一、转向传动比概念二、设置转向传动比1、C factor概念2、Steer Kinematics概念3、传动比计算公式 三、转向传动比验证 一、转向传动比概念 转向传动比&#xff08;Steering Ratio&#xff09;表示方向盘转动角度与车轮转动角度之间的关系。公式如下&#xff1a; 转向…

电脑怎么录音?分享2种音频录制方法

在日常生活和工作中&#xff0c;我们经常需要录制电脑上的音频&#xff0c;无论是为了记录会议内容、保存网络课程&#xff0c;还是为了制作自己的音频素材&#xff0c;录音功能都显得尤为重要。那么电脑怎么录音&#xff1f;本文将详细介绍2种方法教你如何在电脑上进行录音&am…

Ajax的应用

1. Ajax Ajax是Asynchronous Javascript And XML&#xff08;异步JavaScript和XML&#xff09;的缩写。 Ajax技术描述了使用脚本操纵HTTP和Web服务器进行数据交换&#xff0c;在页面不刷新的情况下&#xff0c;实现页面的局部更新。 重点&#xff1a; Ajax 是一种在无需重新加…

C++设计模式——Facade外观模式

一&#xff0c;外观模式简介 外观模式是一种结构型设计模式&#xff0c; 又称为门面模式&#xff0c;也是一种基于创建对象来实现的模式&#xff0c;为子系统中的各组接口的使用提供了统一的访问入口。 外观模式对外提供了一个对象&#xff0c;让外部客户端(Client)对子系统的…

四十七、openlayers官网示例Image Filters——给地图添加锐化、浮雕、边缘等滤镜效果

官网demo示例&#xff1a; Image Filters 这篇讲的是如何给地图添加滤镜。 一看代码&#xff0c;&#xff0c;好家伙&#xff0c;信息量满满&#xff0c;全都看不懂。。。 咱只能一段一段扒。。。 首先添加一个底图到地图上&#xff0c;这个好理解。 const imagery new Til…

macOS vscode常用快捷键

1、shiftoption上下箭头 复制当前行 2、commandd 选定多个相同的单词 先双击选定一个单词&#xff0c;然后按下commandd 依次选中要修改的单词&#xff0c;直接修改即可 3、全局替换某个单词 comandh 4、快速定位到某一行 controlg 5、选中某个区域 shiftoption&#xff0c;然…

Adobe Photoshop cc快速抠图与精致抠图方法

一、背景 Photoshop cc绝对是最好用的抠图and修图软件&#xff0c;但是即使最简单的抠图&#xff0c;每次用时都忘记怎么做&#xff0c;然后再去B站搜&#xff0c;非常费时&#xff0c;下面记录一下抠图过程&#xff0c;方便查阅。 一、Adobe Photoshop快速抠图 选择——主体…

web系统数据库敏感数据处理

一、前言 web系统数据库中保存的公民信息不允许明文存储&#xff0c;比如手机号&#xff0c;身份证号&#xff0c;收货地址等。 二、处理方式 数据库中密文存储&#xff0c;web通过注解的方式对数据加解密处理&#xff0c;下面是处理方法 1、编写接口 public interface E…

提取人脸——OpenCV

提取人脸 导入所需的库创建窗口显示原始图片显示检测到的人脸创建全局变量定义字体对象定义一个函数select_image定义了extract_faces函数设置按钮运行GUI主循环运行显示 导入所需的库 tkinter&#xff1a;用于创建图形用户界面。 filedialog&#xff1a;用于打开文件对话框。 …

【JS】上传文件显示文件的为空,显示的文件参数内容只有uid

上传的文件参数file里面只包含uid&#xff0c;没有其他信息 例子解决办法 例子 例如使用elment ui的el-upload组件上传文件&#xff0c;会导致上传的文件参数file里面只包含uid&#xff0c;没有其他信息&#xff0c;如图&#xff1a; 正确应为如下图&#xff1a; 解决办法 …

MySQL 基本语法讲解及示例(上)

第一节&#xff1a;MySQL的基本操作 1. 创建数据库 在 MySQL 中&#xff0c;创建数据库的步骤如下&#xff1a; 命令行操作 打开 MySQL 命令行客户端或连接到 MySQL 服务器。 输入以下命令创建一个数据库&#xff1a; CREATE DATABASE database_name;例如&#xff0c;创建一…