SpringCloud-RabbitMQ消息模型

news2024/9/24 15:14:56

本文深入介绍了RabbitMQ消息模型,涵盖了基本消息队列、工作消息队列、广播、路由和主题等五种常见消息模型。每种模型都具有独特的特点和适用场景,为开发者提供了灵活而强大的消息传递工具。通过这些模型,RabbitMQ实现了解耦、异步通信以及高效的消息路由,为分布式系统的开发和部署提供了可靠的基础。阅读本文,读者将深入了解RabbitMQ不同消息模型的应用场景和使用方法,为构建可靠的消息传递系统提供了有益的指导。


一、RabbitMQ消息模型介绍

RabbitMQ 是一种高度可扩展的消息代理,其消息模型基于 AMQP(Advanced Message Queuing Protocol)协议,提供了灵活可靠的消息传递机制。

以下是 RabbitMQ 的核心消息模型组成部分:

组成部分功能
生产者 (Producer)生产者负责产生和发送消息到 RabbitMQ 服务器。
将消息发布到特定的交换机(Exchange)。
交换机 (Exchange)交换机是消息的分发中心,接收生产者发送的消息,并将其路由到一个或多个队列。RabbitMQ 提供不同类型的交换机,如直连交换机(direct)、主题交换机(topic)、扇出交换机(fanout)、头交换机(headers)等,以满足不同的路由需求。
队列 (Queue)队列是消息的存储地点,消息在队列中等待被消费。
消息按照一定的规则存储在队列中,等待消费者订阅并处理。
绑定 (Binding)绑定定义了交换机如何将消息路由到特定的队列。
绑定规则由消费者在订阅队列时指定,确保消息按照预期的方式路由。
消费者 (Consumer)消费者订阅一个或多个队列,接收并处理队列中的消息。消费者从队列中获取消息,完成相应的业务逻辑,然后应答(acknowledge)消息。
路由键 (Routing Key)路由键是消息从生产者到达交换机时的附加信息,用于指导消息路由到特定的队列。路由键的值与交换机类型和绑定规则相关。

RabbitMQ 的消息模型允许灵活的消息路由和传递,提供了高度可靠性和可伸缩性。生产者通过交换机将消息发送到队列,而消费者则订阅队列并处理消息。这种模型使得系统能够实现解耦、异步通信,同时确保消息在分布式环境中的可靠传递。


二、RabbitMQ常见消息模型

MQ(消息队列)在应用中有多种常见的消息模型,其中包括以下五种:

1、基本消息队列

基本消息队(Basic Queue) 列是最简单的消息传递模型。在这个模型中,生产者发送包含简单信息如 "Hello World!" 的消息到队列,而消费者则接收并处理这些消息。这种模型适用于简单的场景,如需要一对一通信的情况。

示意图:


2、工作消息队列

工作消息队列(Work Queue)用于在多个工作者(消费者)之间分发任务。生产者将任务发送到队列,多个工作者可以并发地处理这些任务。这种模型有效地实现了任务的分发和并行处理。

示意图:


3、发布订阅

发布订阅(Publish/Subscribe) 模型采用广播方式,生产者将消息发送到交换机,多个队列通过订阅交换机接收消息,实现一对多的消息传递。

根据交换机类型不同,发布订阅模型又分为三种:

① 广播(Fanout Exchange)

广播交换机(Fanout Exchange)是一种简单而强大的消息传递模型。当生产者发送消息到Fanout Exchange时,该交换机会将消息广播到所有与之绑定的队列,无论它们的路由键是什么。这使得多个队列能够同时接收相同的消息,实现了一对多的消息传递

示意图:


② 路由(Direct Exchange)

直连交换机(Direct Exchange)通过使用指定的路由键,将消息传递到与之匹配的队列。这种模型适用于需要将消息精确路由到特定队列的场景。生产者发送消息时,可以指定一个或多个路由键,而队列在绑定交换机时也需要指定相应的路由键,从而实现精准的消息路由。

示意图:


③ 主题(Topic)

主题交换机(Topic Exchange)允许消息的路由键与队列的绑定模式进行模糊匹配,从而实现更灵活的消息订阅和路由。路由键可以使用通配符(和#),其中星号()代表一个单词,井号(#)代表零个或多个单词。这种模型使得队列能够订阅符合特定模式的消息,而不仅仅是固定的路由键。

示意图:

这五种消息模型展示了RabbitMQ在不同场景下的应用,为开发者提供了多样的选择,以满足各种消息传递需求。  


三、RabbitMQ消息模型总结

RabbitMQ作为高度可扩展的消息代理,其消息模型基于AMQP协议,提供了强大的消息传递机制。核心组成部分包括生产者、交换机、队列、绑定和消费者等。消息模型允许实现灵活的消息路由和传递,提供了高度可靠性和可伸缩性。通过交换机将消息发送到队列,消费者订阅队列并处理消息,实现了解耦、异步通信,确保消息在分布式环境中的可靠传递。 ​

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

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

相关文章

数据结构(一)——概述

一、绪论 1.1数据结构的基本概念 数据:用来描述客观事物的数、计算机中是字符及所有能输入并被程序识别和处理的符号的集合。 数据元素:数据的基本单位,一个数据元素可由若干数据项组成。 数据结构:指相互之间存在一种或多种特…

C++:Vector的使用

一、vector的介绍 vector的文档介绍 1. vector是表示可变大小数组的序列容器。 2. 就像数组一样,vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问,和数组一样高效。但是又不像数组,它的大小是可以…

解决win10系统cmd命令无法使用ssh问题

目录 问题说明:在使用ssh命令连接虚拟机地址时,出现了以下报错:​编辑 解决方法如下: 1.打开Windows设置,搜索点击添加可选功能: 2.点击添加功能: 3.安装Open SSH客户端和Open SSH服务器: …

基于Python3的数据结构与算法 - 10 计数排序

一、问题 对列表进行排序,已知列表中的数范围都在0到100之间。设计时间复杂度为O(n)的算法。 二、解决思路 我们已知数字的范围,那么我们可以将数字的个数得到: 例如:有一个0~5的列表 [1,3,2,4,1,2,3,1,3,5] 则共有0个0&am…

Tomcat(二) 动静分离

一、(TomcatNginx)动静分离 1、单机反向代理 利用 nginx 反向代理实现全部转发至指定同一个虚拟主机 客户端curl www.a.com 访问nginx服务,nginx服务通过配置反向代理proxy_pass www.a.com:8080,最终客户端看到的是www.a.com 实验中:7-3 做客…

保姆级GeoWebCache矢量瓦片切片流程

1矢量切片解决方案 1.1Geoserver配置geowebcache插件 参考文章 (53条消息) 独立安装geoservergeowebcache发布arcgis切片服务_itouch_ok的专栏-CSDN博客 1.将下载好的geoserver 2.19.3安装部署 将下载好的geowebcache 2.19.3的war包解压到 GeoServer 安装目录下./usr/loc…

两天学会微服务网关Gateway-Gateway HelloWorld快速入门

锋哥原创的微服务网关Gateway视频教程: Gateway微服务网关视频教程(无废话版)_哔哩哔哩_bilibiliGateway微服务网关视频教程(无废话版)共计17条视频,包括:1_Gateway简介、2_Gateway工作原理、3…

SpringBoot 自定义映射规则resultMap collection一对多

介绍 collection是封装一对多关系的,通常情况下是一个列表,association是一对一,通常情况是一个对象。例如:查询班级下所有的学生,一个班级可以有多个学生,这就是一对多。 案例 有一个学生表&#xff0c…

重构笔记系统:Docker Compose在微服务架构中的应用与优化

虽然我的笔记系统的开发是基于微服务的思想,但是在服务的配置和编排上感觉还是不太合理,具体来说,在开发上的配置和在生产上的配置差别太大。现在规模小,后面规模变大,估计这一块会成为系统生长的瓶颈。 因此&#xff…

优先级队列(Java )

目录 一、 优先级队列1、概念 二、优先级队列的模拟实现1、堆的概念2、堆的存储方式 三、堆的创建1、堆向下调整2、堆的创建3、建堆的时间复杂度 四、堆的插入与删除1、堆的插入2、堆的删除 五、用堆模拟实现优先级队列 一、 优先级队列 1、概念 优先级队列(Priori…

Windows Docker 部署 Jenkins

一、简介 今天介绍一下在 Windows Docker 中部署 Jenkins 软件。在 Windows Docker 中,分为两种情况 Linux 容器和 Windows 容器。Linux 容器是通常大多数使用的方式,Windows 容器用于 CI/CD 依赖 Windows 环境的情况。 二、Linux 容器 Linux 容器内部…

vue中使用echarts实现人体动态图

最近一直处于开发大屏的项目,在开发中遇到了一个小知识点,在大屏中如何实现人体动态图。然后看了下echarts官方文档,根据文档中的示例调整出来自己想要的效果。 根据文档上发现 series 中 type 类型设置为 象形柱形图,象形柱图是…

[HackMyVM]靶场 Quick3

kali:192.168.56.104 主机发现 arp-scan -l # arp-scan -l Interface: eth0, type: EN10MB, MAC: 00:0c:29:d2:e0:49, IPv4: 192.168.56.104 Starting arp-scan 1.10.0 with 256 hosts (https://github.com/royhills/arp-scan) 192.168.56.1 0a:00:27:00:00:05 (U…

解密Lawnchair:打造个性化极致的Android桌面体验

解密Lawnchair:打造个性化极致的Android桌面体验 1. 简介 Lawnchair是一款知名的Android桌面定制工具,旨在为用户提供个性化极致的桌面体验。作为一个开源项目,Lawnchair融合了简洁、灵活和强大的特点,让用户能够自由定制其Andro…

b站小土堆pytorch学习记录—— P17 土堆说卷积操作

文章目录 一、前置知识什么是卷积操作 二、代码 一、前置知识 什么是卷积操作 推荐几个高赞博客: 卷积最容易理解的解释 卷积神经网络(CNN)详细介绍及其原理详解 还有pytorch官网的动态图: pytorch卷积 二、代码 import t…

免费的ChatGPT网站( 7个 )

ChatGPT 是由 OpenAI 公司研发的一款大型语言模型,它可以实现智能聊天、文本生成、语言翻译等多种功能。以下是 ChatGPT 的详细介绍: 智能聊天:ChatGPT 可以与用户进行自然语言对话,回答用户的问题,提供相关的信息和建…

通义千问1.5(Qwen1.5)大语言模型在PAI-QuickStart的微调与部署实践

作者:汪诚愚(熊兮)、高一鸿(子洪)、黄俊(临在) Qwen1.5(通义千问1.5)是阿里云最近推出的开源大型语言模型系列。作为“通义千问”1.0系列的进阶版,该模型推出…

S4---FPGA-K7板级原理图硬件实战

视频链接 FPGA-K7板级系统硬件实战01_哔哩哔哩_bilibili FPGA-K7板级原理图硬件实战 基于XC7K325TFFG900的FPGA硬件实战框图 基于XILINX 的KINTEX-7 芯片XC7K325FPGA的硬件平台,FPGA 开发板挂载了4 片512MB 的高速DDR3 SDRAM 芯片,另外板上带有一个SODIM…

Python爬虫实战(基础篇)—13获取《人民网》【最新】【国内】【国际】写入Word(附完整代码)

文章目录 专栏导读背景测试代码分析请求网址请求参数代码测试数据分析利用lxml+xpath进一步分析将获取链接再获取文章内容测试代码写入word完整代码总结专栏导读 🔥🔥本文已收录于《Python基础篇爬虫》 🉑🉑本专栏专门针对于有爬虫基础准备的一套基础教学,轻松掌握Py…

深度学习-Pytorch实现经典VGGNet网络

深度学习-Pytorch实现经典VGGNet网络 深度学习中,经典网络引领一波又一波的技术革命,从LetNet到当前最火的GPT所用的Transformer,它们把AI技术不断推向高潮。2012年AlexNet大放异彩,它把深度学习技术引领第一个高峰,打…