当前位置: 首页 > news >正文

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.xdnf.cn/news/1032643.html

相关文章:

  • 精益数据分析(104/126):免费移动应用的用户活跃率与付费转化优化策略
  • STM32F4通用定时器TIM9-TIM14讲解及PWM呼吸灯实例解读
  • 1 Studying《Arm A715 Software Optimization Guide》
  • 【Python-Day 26】解锁时间魔法:深入解析 time 与 datetime 模块
  • 双重特征c++
  • 共享项目中使用Wpf和Winform——c# CAD二次开发
  • 浏览器指纹-探究前端如何识别用户设备
  • 2.4.1 ASPICE的编码与单元测试
  • 新能源汽车电子架构革命:深度解析AUTOSAR标准与实践
  • 基于U-Net与可分离卷积的肺部分割技术详解
  • error:MISCONF Redis is configured to save RDB snapshots
  • Android 蓝牙默认名称设置分析总结
  • Laravel模板Blade 用法 x-layouts.guest 和x-guest-layout 什么区别
  • 《深度学习:基础与概念》第一章 学习笔记与思考
  • 数据结构 学习 链表 2025年6月14日08点01分
  • 微店商品详情API接口Python攻略
  • 代码随想录算法训练营第三十二天 |【动态规划1-13】
  • 从汇编的角度揭开C++ this指针的神秘面纱(上)
  • Excel大厂自动化报表实战(互联网金融-数据分析周报制作下)
  • Python的“Rstudio“——Pycharm
  • Vue3中v-bind指令用法详解
  • 电脑出问题了,无网络环境下一键快速重装系统
  • 阿尔茨海默病谱系中APOE-ε4携带者的性别特异性超兴奋性:一项纵向fMRI与DTI研究
  • 【消息队列】——消息队列的高可用与容灾设计
  • docker 安装jobe服务器配置Moodle的coderunner插件
  • .net5中用Redis存放session
  • Flask入门:从零搭建Python Web应用
  • JavaScript基础-事件委托(代理、委派)
  • JavaEE初阶第一期:计算机是如何 “思考” 的(上)
  • TerraFE 脚手架开发实战系列(一):项目架构设计与技术选型