RabbitMQ的交换机和队列概念


🏪 场景:一个外卖平台的后台系统

假设你开了一家在线外卖平台:

  • 饭店是消息的生产者(Producer)
  • 顾客是消息的消费者(Consumer)
  • 你开的外卖平台就是RabbitMQ消息系统

🔁 第一部分:核心概念解析

📦 1. 队列(Queue)—— 外卖存放柜

[ 队列就像小区门口的快递柜 ]
┌──────────────┐
│   队列(Queue)  │
│  ┌────────┐  │
│  │ 订单1  │  │<--- 骑手放外卖
│  ├────────┤  │
│  │ 订单2  │  │
│  ├────────┤  │
│  │ 订单3  │  │---> 顾客取外卖
│  └────────┘  │
└──────────────┘
  • 作用:临时存储消息(外卖订单)的容器
  • 特点
    • 先进先出(先放的订单先被处理)
    • 可以持久化(断电重启订单不丢失)
    • 可设置容量限制(防止爆单)

🔀 2. 交换机(Exchange)—— 智能分拣中心

[ 交换机像外卖平台的调度中心 ]┌──────────────┐餐厅送来订单 ─>│  交换机       │─> 根据订单地址分发│ (Exchange)   │└──────┬───────┘│┌──────────────▼──────────────┐│      不同小区的快递柜        │├───────────┬─────────┬────────┤│ 浦东队列  │ 浦西队列 │ 松江队列│└───────────┴─────────┴────────┘
  • 作用:接收消息,并根据路由规则发给对应队列
  • 核心工作
    // 伪代码:交换机的工作逻辑
    void handleMessage(Message msg) {if (是广播消息) 发送给所有队列;       // Fanout模式else if (匹配路由键) 发到指定队列;   // Direct模式else if (模糊匹配) 发到多个队列;     // Topic模式
    }
    

🔧 第二部分:交换机类型和业务场景

1️⃣ 直连交换机(Direct Exchange)—— 精准配送

[ 定向配送场景 ]┌────────┐支付消息 ─>│ 交换机 ├───> [支付队列] → 财务系统└───┬────┘└─────> [订单队列] → 订单系统(路由键:order)
  • 适用场景:订单状态更新、支付通知
  • 代码绑定
    // 绑定队列到交换机,并指定路由键
    channel.queueBind("支付队列", "订单交换机", "payment");
    channel.queueBind("订单队列", "订单交换机", "order");
    

2️⃣ 扇形交换机(Fanout Exchange)—— 小区广播

[ 小区通知场景 ]┌─────────────┐物业通知─>│  广播交换机 ├───> [1号楼快递柜] └──────┬──────┘├───> [2号楼快递柜]└───> [3号楼快递柜]
  • 适用场景:系统公告、群发消息
  • 特点:无视路由键,消息直接复制到所有绑定队列

3️⃣ 主题交换机(Topic Exchange)—— 智能分类

[ 根据标签定向推送 ]┌─────────┐新闻"体育.NBA" ───> │ 交换机  ├─> [体育队列] (*.NBA)└───┬─────┘└───> [热点队列] (热点.*) 
  • 路由键规则
    • * 匹配1个词(如 天气.上海天气.*
    • # 匹配0或多个词(如 新闻.体育.NBA新闻.#
  • 场景:新闻分类、日志分级收集

🧩 第三部分:完整消息流转流程

 饭店(生产者)                    顾客(消费者)│                             ▲│ 1.下订单                     │ 6.吃外卖▼                             │
┌─────────────────┐               ┌────────────┐
│  外卖平台交换机  │ 3.放指定格子     │  队列      │
│  (Exchange)     ├─────┬───────> │ (Queue)    │
└─────────────────┘     │         └────────────┘│      │2.通知调度中心       │ 4.查看待取外卖│     ┌▼───────────────────┐ │ 5.从柜子取外卖└─────┤  绑定规则          ├─┘│ (queueBind路由规则)│└───────────────────┘

💻 对应代码示例

// 1. 饭店声明交换机 (类似开通分店渠道)
channel.exchangeDeclare("订单交换机", "direct");// 2. 物业声明队列 (类似安装外卖柜)
channel.queueDeclare("浦东外卖柜", true, false, false, null);// 3. 建立绑定关系 (类似设置配送范围)
channel.queueBind("浦东外卖柜", "订单交换机", "pudong");// 4. 饭店发送订单
channel.basicPublish("订单交换机", "pudong", null, "鱼香肉丝饭".getBytes());// 5. 顾客监听自己的外卖柜
channel.basicConsume("浦东外卖柜", true, (consumerTag, delivery) -> {System.out.println("收到外卖: " + new String(delivery.getBody()));
}, consumerTag -> {});

📌 关键总结

概念现实比喻核心作用开发者注意事项
交换机外卖调度中心决定消息去哪(不存消息)必须选择正确的交换机类型
队列小区快递柜临时存消息要配置持久化/长度限制/消费者数量
绑定外卖柜安装位置对应表建立交换机和队列映射关系路由键是消息分类的关键标签

⚠️ 易错点提醒
很多初学者直接发消息到队列(不经过交换机),相当于饭店把外卖直接塞进某个快递柜 —— 可以运行但失去灵活性!正规做法是通过交换机路由,后续拓展才方便。

现在再回头看你的代码:

// 创建队列(相当于安装一个快递柜)
channel.queueDeclare("订单队列", true, false, false, null); 

就明白这个快递柜的特性:

  • true:耐用的柜子(服务器重启订单还在)
  • false:不独占(多个骑手能同时投递)
  • false:有人用时不会自动拆除
  • null:不需要特殊参数

要真正启用它,还需要绑定到一个交换机!就像是告诉调度中心"这个柜子接收浦东地区的外卖订单"。

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

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

相关文章

德国马克斯·普朗克数学研究所:几何朗兰兹猜想

2025年科学突破奖 4月5日在美国洛杉矶揭晓&#xff1a;数学突破奖&#xff1a;德国马克斯普朗克数学研究所&#xff1a;几何朗兰兹猜想 德国马克斯普朗克数学研究所&#xff08;Max Planck Institute for Mathematics, MPIM&#xff09;在几何朗兰兹猜想的研究中扮演了核心角色…

TerraFE 脚手架开发实战系列(一):项目架构设计与技术选型

TerraFE 脚手架开发实战系列&#xff08;一&#xff09;&#xff1a;项目架构设计与技术选型 前言 在前端开发中&#xff0c;项目初始化往往是一个重复且繁琐的过程。每次新建项目都需要配置 webpack、安装依赖、设置目录结构等&#xff0c;这些重复性工作不仅浪费时间&#…

准确--CentOS 7.9在线安装docker

一、安装Docker前的准备工作 操作系统版本为CentOS 7.9&#xff0c;内核版本需要在3.10以上。确保能够连通互联网&#xff0c;为避免网络异常&#xff0c;建议关闭Linux的防火墙&#xff08;生产环境下请根据实际情况设置防火墙出入站规则&#xff09;。 # 查看内核版本 sudo…

中兴B860AV1.1强力降级固件包

中兴B860AV1.1强力降级固件包 关于中兴b860av1.1顽固盒子降级教程终极版 将附件解压好以后&#xff0c;准备一个8G以下的U盘重新格式化为FAT32格式后&#xff0c;并插入电脑 将以下文件及文件夹一同复制到优盘主目录下&#xff08;见下图&#xff09; 全选并复制到U盘主目录下&…

nacos-作为注册中心与springcloud整合(三)

前一篇文章nacos-简介和初体验&#xff08;一&#xff09;我们已经在服务器部署了nacos应用了。 在另外一篇文章中nacos-作为配置中心与springcloud整合&#xff08;二&#xff09;已经作为配置中心整合到springcloud 接下来让我们尝试把nacos作为注册中心和springcloud中整合&…

Seata的TC(事务协调器)高可用如何实现?

Seata的TC&#xff08;事务协调器&#xff09;确实运行在Seata服务进程中&#xff0c;其高可用实现和宕机恢复主要通过以下机制实现&#xff1a; 一、高可用架构 集群部署 多TC节点组成集群&#xff0c;通过注册中心&#xff08;如Nacos&#xff09;实现服务发现采用Raft协议实…

Mac安装docker desktop

一、背景 最近在学习Spring AI&#xff0c;于是在GitHub上找了个开源项目&#xff0c;个人觉得还是比较适合有Java基础和AI基础的同学学习的。GitHub地址如下&#xff1a; https://github.com/qifan777/dive-into-spring-ai 但是看了下运行环境需要 MySQL 8 Redis-Stack n…

【算法深练】二分答案:从「猜答案」到「精准求解」的解题思路

目录 前言 二分求最小值 1283. 使结果不超过阈值的最小除数 2187. 完成旅途的最少时间 1011. 在 D 天内送达包裹的能力 875. 爱吃香蕉的珂珂 3296. 移山所需的最少秒数 475. 供暖器 2594. 修车的最少时间 1482. 制作 m 束花所需的最少天数 3048. 标记所有下标的最早秒…

基于RK3588,飞凌教育品牌推出嵌入式人工智能实验箱EDU-AIoT ELF 2

在AIoT技术驱动产业变革的浪潮中&#xff0c;嵌入式人工智能已成为工业物联网、智慧交通、智慧医疗等领域创新突破的关键引擎。飞凌嵌入式教育品牌ElfBoard立足产业前沿&#xff0c;重磅推出嵌入式人工智能实验箱EDU-AIoT ELF 2&#xff0c;以“软硬协同、产教融合”为设计理念…

51单片机-IO扩展模块 pcf8575

PCF8575介绍 PCF8575 是 NXP&#xff08;原飞利浦半导体&#xff09;生产的一款通用 IC 总线 I/O 扩展器芯片&#xff0c;主要用于微控制器&#xff08;如 Arduino、STM32 等&#xff09;的 I/O 端口扩展。 主要特性 16位并行 I/O 端口&#xff1a;可以配置为输入或输出 IC 总…

Python3 学习(菜鸟)-02基本数据类型

1.多变量赋值 多变量被赋予相同的数值 多变量被赋予不同的数值 2.数值运算 除法 /&#xff1a;返回一个浮点数 除法 //&#xff1a;返回一个整数 3.列表 加号和星号 加号 是列表连接运算符 星号 * 是重复操作 list [ abcd, 786 , 2.23, runoob, 70.2 ] # 定义一个…

『uniapp』搜索功能+商品列表滚动效果(详细图文注释)

目录 预览效果准备工作代码分析与思路1. 页面结构主容器:`menber-container`搜索框:`u-search-inner`菜单:`u-menu-wrap`2. 数据模型`data()` 中的数据定义:3. 生命周期`onLoad(options)``onReady()``mounted()`4. 方法`search()``searchClear()``swichMenu(index)``getElRe…

微服务--消息队列mq

1. mq简介 消息队列是分布式系统中的异步通信中间件&#xff0c;采用"生产者-消费者"模型实现服务间解耦通信 核心作用 服务解耦异步处理流量削峰数据同步最终一致性 消息队列模式 发布/订阅模式&#xff1a;一对多广播工作队列模式&#xff1a;竞争消费死信队列…

第26节 Node.js 事件

Node里很多对象会分发事件&#xff1a; 每次有连接的时候net.Server会分发事件&#xff0c;当文件打开的时候fs.readStream会分发事件。所有能分发事件的对象都是 events.EventEmitter的实例。通过require("events");能访问这个模块。 一般来说&#xff0c;事件名都…

LangChain + MCP + vLLM + Qwen3-32B 构建本地私有化智能体应用

一、私有化智能体应用 在本专栏的前面文章基于Spring AI MCP实现了本地 ChatBI 问答应用&#xff0c;本文还是依据该场景&#xff0c;采用 LangChain vLLM Qwen3-32B MCP 技术栈构建该流程&#xff0c;整体过程如下图所示&#xff1a; 实现效果如下所示&#xff1a; 关于 M…

AKS升级路线最佳实践方案

前言 Kubernetes 社区大约每 4 个月发布次要版本&#xff0c;次要版本包括新增功能和改进。补丁发布更为频繁&#xff08;有时每周都会发布&#xff09;&#xff0c;适用于次要版本中的关键 Bug 修复。修补程序版本包括针对安全漏洞或主要 bug 的修复。对于受支持版本列表以…

树莓派智能小车基本移动实验指导书

1.安装LOBOROBOT库函数 LOBOROBOT.py代码如下&#xff1a; #!/usr/bin/python # -*- coding: utf-8 -*-import time import math import smbus import RPi.GPIO as GPIODir [forward,backward, ]class PCA9685:# Registers/etc.__SUBADR1 0x02__SUBADR2 …

如何对目标检测算法RT-DETR进行创新和改进:突破瓶颈,提升性能!

更多精彩&#xff0c;详见文末~~~ 在目标检测的高速发展中&#xff0c;RT-DETR作为DETR&#xff08;DEtection TRansformer&#xff09;的高效变体&#xff0c;凭借其优异的性能和较快的推理速度&#xff0c;已经成为许多实际应用中的首选算法。然而&#xff0c;尽管RT-DETR在…

Java-String

前言 package com.kjxy.st;public class TestString1 {public static void main(String[] args) {String s1 "hello";String s2 "hello";String s3 new String("hello");String s4 new String("hello");System.out.println(s1 s2…

计算机组成原理——C/存储系统

&#x1f308;个人主页&#xff1a;慢了半拍 &#x1f525; 创作专栏&#xff1a;《史上最强算法分析》 | 《无味生》 |《史上最强C语言讲解》 | 《史上最强C练习解析》|《史上最强C讲解》|《史上最强计组》|《史上最强数据结构》 &#x1f3c6;我的格言&#xff1a;一切只是时…