个人简历面试复习-----rabbitmq篇(一)

目录

1.七种工作模式

[1. 1简单模式(Simple)](#1. 1简单模式(Simple))

核心

角色

适用场景

[1.2 工作队列模式(Work Queues)](#1.2 工作队列模式(Work Queues))

核心

关键特性

适用场景

[1.3 发布 / 订阅模式(Publish/Subscribe)](#1.3 发布 / 订阅模式(Publish/Subscribe))

核心

关键

适用场景

[4. 路由模式(Routing)](#4. 路由模式(Routing))

核心

关键

适用场景

[5. 主题模式(Topics)⭐ 最常用](#5. 主题模式(Topics)⭐ 最常用)

核心

通配符规则

示例

适用场景

[6. 头部模式(Headers)](#6. 头部模式(Headers))

核心

关键

适用场景

[7. RPC 模式(Remote Procedure Call)](#7. RPC 模式(Remote Procedure Call))

核心

流程

适用场景

[7 种模式对比速查表](#7 种模式对比速查表)

核心总结


1.七种工作模式

1. 1简单模式(Simple)

核心

最简单的一对一模式 :1 个生产者 → 1 个队列 → 1 个消费者无交换机,直接使用默认交换机(AMQP default

角色

  • 生产者:发送消息到队列
  • 队列:存储消息
  • 消费者:监听并消费消息

适用场景

单一功能的简单业务,如:单线程日志记录、简单通知

1.2 工作队列模式(Work Queues)

核心

一对多竞争消费 :1 个生产者 → 1 个队列 → 多个消费者 消息只能被一个消费者消费,实现负载均衡

关键特性

  • 默认:轮询分发(平均分配消息)
  • 配置后:能者多劳(处理快的消费者多消费)

适用场景

任务异步处理、流量削峰,如:订单处理、视频转码

1.3 发布 / 订阅模式(Publish/Subscribe)

核心

广播模式 :1 个生产者 → 1 个交换机(fanout) → 多个队列 → 多个消费者所有绑定的消费者都能收到全量消息

关键

交换机类型:fanout(扇形 / 广播)不处理路由键,直接群发所有队列

适用场景

全员通知、多系统同步数据,如:公告推送、缓存更新

4. 路由模式(Routing)

核心

定向分发 :生产者 → direct 交换机 → 按路由键 匹配队列只有路由键完全匹配的消费者才能收到消息

关键

交换机类型:direct(直连)必须指定 routing key 绑定

适用场景

按类型筛选消息,如:错误日志单独推送、订单状态定向通知

5. 主题模式(Topics)⭐ 最常用

核心

模糊匹配路由 :生产者 → topic 交换机 → 通配符路由键支持模糊匹配,比路由模式更灵活

通配符规则

  • *:匹配一个单词
  • #:匹配零个或多个 单词单词分隔符:.

示例

路由键:user.order.pay匹配:user.*.*user.##.pay

适用场景

复杂业务筛选,如:按用户 / 商品 / 订单类型精准推送

6. 头部模式(Headers)

核心

不使用路由键 ,通过消息头(headers) 匹配队列基于键值对匹配,性能较差,极少使用

关键

交换机类型:headers匹配规则:x-match(all/any)

适用场景

极特殊的复杂匹配需求(优先用主题模式替代)

7. RPC 模式(Remote Procedure Call)

核心

远程调用模式 :客户端发送消息 → 服务端处理 → 原路返回结果实现同步调用,像调用本地方法一样调用远程服务

  1. 客⼾端发送消息到⼀个指定的队列, 并在消息属性中设置replyTo字段, 这个字段指定了⼀个回调队列, ⽤于接收服务端的响应.
  2. 服务端接收到请求后, 处理请求并发送响应消息到replyTo指定的回调队列
  3. 客⼾端在回调队列上等待响应消息. ⼀旦收到响应,客⼾端会检查消息的correlationId属性,以 确保它是所期望的响应

流程

  1. 客户端发送请求(带唯一 ID)
  2. 服务端消费处理
  3. 服务端发送响应到回调队列
  4. 客户端接收响应

适用场景

需要同步等待结果的场景,如:支付校验、数据查询

7 种模式对比速查表

模式 交换机类型 核心特点 消息消费方式 推荐度
简单模式 默认 一对一 一个消费者消费 ⭐⭐
工作队列 默认 一对多竞争 一个消费者消费 ⭐⭐⭐⭐
发布订阅 fanout 广播 所有消费者消费 ⭐⭐⭐
路由模式 direct 精准路由键匹配 匹配的消费者消费 ⭐⭐⭐⭐
主题模式 topic 模糊路由键匹配 匹配的消费者消费 ⭐⭐⭐⭐⭐
头部模式 headers 消息头匹配 匹配的消费者消费
RPC 模式 默认 同步请求响应 双向通信 ⭐⭐⭐

核心总结

  1. 基础场景:简单模式、工作队列
  2. 广播场景:发布 / 订阅(fanout)
  3. 精准匹配:路由模式(direct)
  4. 复杂匹配主题模式(topic)------ 企业最常用
  5. 特殊场景:头部模式(不用)、RPC 模式(同步调用)
相关推荐
一只机电自动化菜鸟10 小时前
一建机电备考笔记(33) 机电专业技术(起重技术-吊装方案)(含考频+题型)
经验分享·笔记·学习·职场和发展·课程设计
Cosolar10 小时前
大模型应用开发面试 • 每日三题|Day 003|多Agent系统中的通信协议、冲突解决和一致性保障
人工智能·后端·面试
张元清12 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试
暗不需求14 小时前
前端性能优化 防抖与节流完全指南:从原理到最佳实践
前端·javascript·面试
Henray202414 小时前
最低公共祖先 LCA
java·面试
Raink老师15 小时前
【AI面试临阵磨枪-54】如何监控 AI 系统:成功率、延迟、Token 消耗、幻觉率、调用量
人工智能·面试·职场和发展
Languorous.16 小时前
C++数据结构进阶|并查集(Union-Find)详解:从原理到面试实战
数据结构·c++·面试
Languorous.16 小时前
C++数据结构进阶|堆(Heap)详解:从手写实现到面试高频实战
数据结构·c++·面试
雨辰AI17 小时前
面试题:人大金仓事务隔离级别、MVCC 机制详解(与MySQL差异对比)
数据库·后端·mysql·面试·政务
Henray202418 小时前
三个线程交替打印ABC
java·面试