【消息队列】RabbitMQ基本认识

news2025/5/18 19:28:05

目录

一、基本概念

1. 生产者(Producer)

2. 消费者(Consumer)

3. 队列(Queue)

4. 交换器(Exchange)

5. 绑定(Binding)

6. 路由键(Routing Key)

7. 消息确认(ACK)

8. 持久化(Durability)

9. 虚拟主机(Virtual Host)

二、认识MQ控制台及基本操作

1、MQ系统预设的交换机:

2、创建交换机

3、创建队列

4、将交换机与队列绑定(路由)​编辑

5、发送消息

6、查看队列中的消息​编辑

三、交换机类型

1、Fanout交换机

2、Direct交换机

3、Topic交换机

四、数据隔离

1、添加新用户

2、查看用户列表

3、切换到新用户,并创建虚拟主机。

4、回交换机看看


        大家好,今天给大家分享RabbitMQ。MQ呢可以看作一个中间者,我们给MQ发送一条消息,然后其他服务就可以从MQ获取到消息并执行相应的业务。这样的好处就是可以达到异步处理,生产消息的一方只需要把消息发送给MQ即可,无需再关注后续操作,可以继续执行自己的业务。


一、基本概念

下面一些交换机的概念后面会讲,比如路由键什么的如果第一次看不懂没关系

1. 生产者(Producer)

  • 发送消息的应用,将消息发布到 RabbitMQ 的 交换器


2. 消费者(Consumer)

  • 接收消息的应用,从 队列 中订阅并处理消息。


3. 队列(Queue)

  • 存储消息的缓冲区,消息会被暂存在队列中,直到被消费者处理。

  • 特性:可声明为持久化(重启后保留)、独占(仅限当前连接)或自动删除(无消费者时删除)。


4. 交换器(Exchange)

  • 接收生产者发送的消息,并根据规则(绑定、路由键)将消息路由到队列。

  • 常用类型

    • Direct:精确匹配路由键。

    • Fanout:广播到所有绑定队列。

    • Topic:基于通配符匹配路由键(如 logs.*)。

    • Headers:通过消息头属性匹配(不常用)。


5. 绑定(Binding)

  • 连接交换器和队列的规则,定义消息如何从交换器路由到队列。


6. 路由键(Routing Key)

  • 生产者发送消息时指定的键,交换器根据此键决定消息路由到哪些队列。


7. 消息确认(ACK)

  • 手动确认(Manual Acknowledgement):消费者处理完消息后需显式发送 ACK,RabbitMQ 才会从队列删除消息。

  • 自动确认(Auto ACK):消息发送后立即删除,可能导致消息丢失(不推荐生产环境使用)。


8. 持久化(Durability)

  • 队列持久化:声明队列时设置 durable=true,重启后队列保留。

  • 消息持久化:发送消息时设置 delivery_mode=2,确保消息写入磁盘(需配合持久化队列生效)。


9. 虚拟主机(Virtual Host)

  • 逻辑隔离单元,类似独立环境。不同虚拟主机的交换器、队列等资源互相隔离。



二、认识MQ控制台及基本操作

1、MQ系统预设的交换机:


2、创建交换机


3、创建队列


4、将交换机与队列绑定(路由)

完成:


5、发送消息

想交换机发送消息,交换机会根据它自己的类型,将消息路由发送到与他绑定的队列中


6、查看队列中的消息



三、交换机类型

1、Fanout交换机

  • 作用:广播消息,将消息无条件发送到所有绑定的队列

  • 特点

    • 完全忽略路由键(Routing Key)。

    • 每条消息会被复制到所有关联队列。

  • 典型场景

    • 群发通知(如系统广播)。

    • 日志分发到多个消费者。

    • 事件驱动架构中的多服务同步处理。

一句话:无脑广播,一人发送,全员队列接收。


2、Direct交换机

  • 作用精确匹配路由键,将消息发送到与路由键完全一致的绑定队列。

  • 特点

    • 消息的路由键(Routing Key)必须与队列的绑定键(Binding Key)完全相同

    • 一对一或多对一投递(如多个队列绑定相同键时,消息会复制到这些队列)。

  • 典型场景

    • 任务分发(如按任务类型路由到特定队列)。

    • 订单系统中按订单状态分类处理。

    • 需要严格匹配规则的场景(如支付成功/失败消息分离)。

一句话:按键精准投递,一对一或多对一,严格匹配。

示例:在控制台中创建交换机,并设置绑定关系


3、Topic交换机

  • 作用:基于通配符模式匹配路由键,实现灵活的多条件路由

  • 特点

    • 路由键支持通配符:

      • *:匹配一个单词(如 order.* 匹配 order.paid,不匹配 order.paid.email)。

      • #:匹配零或多个单词(如 order.# 匹配 orderorder.paidorder.paid.email)。

    • 绑定键格式为用.分隔的多级路径(如 user.notification.email)。

  • 典型场景

    • 多维度事件分类(如日志分级 error.*warning.*)。

    • 动态路由(如根据用户行为类型+地区分发消息 action.purchase.us)。

    • 订单状态多级处理(如 order.*.failed 匹配所有失败类型)。

一句话通配符匹配路由键,按层级灵活分发。



四、数据隔离

给不同的项目创建不同的用户,然后不同的用户使用不同的虚拟主机,这样就达成了数据的隔离。

1、添加新用户


2、查看用户列表


3、切换到新用户,并创建虚拟主机。

(注意:创建的虚拟主机直接就属于当前登录用户的)

查看虚拟主机:


4、回交换机看看

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

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

相关文章

1T 服务器租用价格解析

服务器作为数据存储与处理的核心设备,对于企业和个人开发者而言至关重要。当涉及到租用 1T 服务器时,价格是大家很为关注的要点。然而,1T 服务器租用一个月的费用并非固定不变,而是受到诸多因素的综合影响。​ 影响 1T 服务器租用…

【JavaWeb】Maven(下)

1 依赖管理 1.1 依赖配置 1.1.1 基本配置 依赖:指当前项目运行所需要的jar包。 一个项目中可以引入多个依赖: 例如:在当前工程中,我们需要用到logback来记录日志,此时就可以在maven工程的pom.xml文件中,引…

openEuler24.03 LTS下安装MySQL8.0.42

目录 前提步骤 删除原有mysql及maridb数据库 安装MySQL 启动MySQL 启动查看MySQL状态 设置MySQL开机自启动 查看登录密码 登录MySQL 修改密码及支持远程连接 远程连接MySQL 前提步骤 拥有openEuler24.03 LTS环境,可参考:Vmware下安装openEule…

gflags 安装及使用

目录 引言 安装 如何用 gflags 库写代码 如何用命令行使用 gflags 库 gflags 库的其他命令行参数 引言 gflags 是 Google 开发的一个开源库,用于 C 应用程序中命令行参数的声明、定义 和解析。 gflags 库提供了一种简单的方式来添加、解析和文档化命令行标…

Linux面试题集合(2)

查看系统磁盘使用,当前目录下所有文件夹的使用情况 df -h du -h 更改目录所有人和所有组,包括里面的文件夹下的文件,递归更改 chown -R newowner:newgroup 目录名 只更改文件所有人或者只更改文件所有组 chown newowner file chgrp newgroup …

致敬经典 << KR C >> 之打印输入单词水平直方图和以每行一个单词打印输入 (练习1-12和练习1-13)

1. 前言 不知道有多少同学正在自学C/C, 无论你是一个在校学生, 还是已经是上班族. 如果你想从事或即将从事软件开发这个行业, C/C都是一个几乎必须要接触的系统级程序开发语言. 虽然现在有Rust更安全的系统级编程语言作为C/C的替代, 但作为入门, C应该还是要好好学的. C最早由B…

基于Llama3的开发应用(二):大语言模型的工业部署

大语言模型的工业部署 0 前言1 ollama部署大模型1.1 ollama简介1.2 ollama的安装1.3 启动ollama服务1.4 下载模型1.5 通过API调用模型 2 vllm部署大模型2.1 vllm简介2.2 vllm的安装2.3 启动vllm模型服务2.4 API调用 3 LMDeploy部署大模型3.1 LMDeploy简介3.2 LMDeploy的安装3.3…

windows 10 做服务器 其他电脑无法访问,怎么回事?

一般我们会先打开win10自己的防火墙策略,但是容易忽略 电脑之间 路由器上的防火墙,此时也需要查看一下,可以尝试先关闭路由器防火墙,如果可以了,再 设置路由器上的防火墙规则。 将路由器的上网设置 改成 路由模式 &a…

Linux进程信号处理(26)

文章目录 前言一、信号的处理时机处理情况“合适”的时机 二、用户态与内核态概念重谈进程地址空间信号的处理过程 三、信号的捕捉内核如何实现信号的捕捉?sigaction 四、信号部分小结五、可重入函数六、volatile七、SIGCHLD 信号总结 前言 这篇就是我们关于信号的最…

报表控件stimulsoft教程:如何在报表和仪表板中创建热图

Stimulsoft Ultimate (原Stimulsoft Reports.Ultimate)是用于创建报表和仪表板的通用工具集。该产品包括用于WinForms、ASP.NET、.NET Core、JavaScript、WPF、PHP、Java和其他环境的完整工具集。无需比较产品功能,Stimulsoft Ultimate包含了…

win32相关(字符编码)

字符编码 ASCII编码 ASCII(American Standard Code for Information Interchange,美国信息交换标准代码)是最基础的字符编码标准,用于在计算机和其他设备中表示文本 基本概念 7位编码: ASCII使用7位二进制数&#x…

使用Langfuse和RAGAS,搭建高可靠RAG应用

大家好,在人工智能领域,RAG系统融合了检索方法与生成式AI模型,相比纯大语言模型,提升了准确性、减少幻觉且更具可审计性。不过,在实际应用中,当建好RAG系统投入使用时,如何判断接收信息是否正确…

android studio导入项目

如果 gradle-8.0-bin.zip 没有下载成功 可以点击进入这个网站:https://services.gradle.org/distributions/ 找到和自己本版相同的gradle-8.0-bin.zip文件找到自己版本进行下载; 如果下载依赖失败, 可以手动下载依赖编译过程中的jar https://repo.maven.apache.org/…

Autosar Nvm下电存储实现方式-基于ETAS工具

文章目录 前言Autosar Nvm相关定义Nvm Ram Block States状态切换Nvm_WriteAll函数NvBlock配置生成代码分析及使用总结前言 Nvm中存储的数据,一般有两种存储方式,一个是立即存,一个是下电存,之前介绍过立即存的配置,本文介绍下电存的配置及实现 Autosar Nvm相关定义 Nvm…

c# 数据结构 树篇 入门树与二叉树的一切

事先声明,本文不适合对数据结构完全不懂的小白 请至少学会链表再阅读 c# 数据结构 链表篇 有关单链表的一切_c# 链表-CSDN博客 数据结构理论先导:《数据结构(C 语言描述)》也许是全站最良心最通俗易懂最好看的数据结构课(最迟每周五更新~~&am…

Python Bug 修复案例分析:asyncio 事件循环异常引发的程序崩溃 两种修复方法

在 Python 异步编程的工作中,asyncio库为我们提供了高效处理并发任务的强大工具。然而,asyncio在使用过程中也可能因为一些细节处理不当而引发 Bug。下面,我们就来深入分析一个因asyncio事件循环异常导致程序崩溃的典型案例。兴趣的友友可以借…

题单:递归求和

宣布一个重要的事情,我的洛谷有个号叫 题目描述 给一个数组 a:a[0],a[1],...,a[n−1]a:a[0],a[1],...,a[n−1] 请用递归的方式出数组的所有数之和。 提示:递推方程 f(x)f(x−1)a[x]f(x)f(x−1)a[x]; 输入格式 第一行一个正整数 n (n≤100)n (n≤100)…

怎么在excel单元格1-5行中在原来内容前面加上固定一个字?

环境: WPS 2024 问题描述: 怎么在excel单元格1-5行中在原来内容前面加上固定一个字? 解决方案: 1.在Excel中,如果您想在单元格的内容前面添加一个固定的字,可以通过以下几种方法实现: 方法…

OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库——mqtt库

准备工作 请依照这篇文章搭建环境 OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库——环境配置_openharmony交叉编译-CSDN博客 下载 wget ftp://ftp.gnutls.org/gcrypt/gnutls/v3.5/gnutls-3.5.9.tar.xz 解压 tar -xf mkdir ./out cd ./out Cmake命…

数据结构 -- 顺序查找和折半查找

查找的基本概念 基本概念 查找:在数据集合中寻找满足某种条件的数据元素的过程 查找表(查找结构):用于查找的数据集合称为查找表,它由同一类型的数据结构元素(或记录)组成 关键字&#xff1…