202526 | 消息队列MQ

消息队列(MQ)全面解析

一、消息队列核心价值

MQ核心能力 解耦 异步 削峰 生产者消费者互不感知 非阻塞调用 缓冲突发流量


二、同步 vs 异步调用对比
维度 同步调用 异步调用(MQ)
通信方式 实时等待响应 触发后立即返回
耦合度 强依赖服务地址 仅依赖消息格式
性能 RT=所有下游耗时之和 RT≈自身处理时间
可靠性 级联失败风险 消息持久化+重试机制
典型场景 支付验证、实时查询 日志处理、订单状态更新

调用流程对比
Client Service Downstream MQ DB 请求 同步调用 响应 返回结果 请求 发消息 立即返回 消费消息 异步处理 Client Service Downstream MQ DB


三、MQ技术选型指南
1. 主流MQ对比
MQ 吞吐量 延迟 顺序保证 事务支持 适用场景
Kafka 100万+/s 毫秒级 ✔️ ✖️ 日志/大数据管道
RocketMQ 10万+/s 毫秒级 ✔️ ✔️ 电商/金融交易
RabbitMQ 1万+/s 微秒级 ✖️ ✔️ 企业级应用
Pulsar 100万+/s 毫秒级 ✔️ ✔️ 多租户/实时分析
2. 选型决策树

是 否 是 否 是 否 需要消息顺序? Kafka/RocketMQ 需要事务? RocketMQ/RabbitMQ 需要高吞吐? Kafka/Pulsar RabbitMQ


四、MQ监控指标体系
指标 正常范围 危险阈值
消息堆积量 < 1万 > 5万
生产消费速率差 < 10% > 30%持续5min
平均处理延迟 < 500ms > 2s
消费者存活数 = 部署实例数 < 50%实例数

五、生产环境最佳实践
1. 可靠性保障
  1. 开启confirm 2. 镜像队列 3. 手动ACK 4. 死信队列 生产者 MQ 集群节点 消费者 异常处理
2. 性能优化
  • Kafkanum.io.threads=CPU核心数*2
  • RabbitMQchannel_max=2047
  • RocketMQsendMessageThreadPoolNums=32
**3. 典型故障处理

是 否 是 否 发现堆积 是否消费卡住? 扩容消费者 是否生产激增? 限流生产端 检查网络/磁盘

相关推荐
于先生吖10 分钟前
国际语言适配拼车系统 JAVA 后端源码 + 同城顺风车功能全解析
java·开发语言
czlczl2002092519 分钟前
KRaft原理
java·zookeeper
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 基于SSM的宜佳家具电商平台为例,包含答辩的问题和答案
java
客卿1231 小时前
最小生成树(贪心)--构造回文串(字符串 + 回文判断 + 构造)
java·开发语言·算法
天启HTTP1 小时前
多线程环境下,动态IP怎么分配最合理
java·服务器·网络
hzb666661 小时前
xd_day32-day40
java·javascript·学习·安全·web安全·tomcat·php
东北甜妹1 小时前
Python脚本
java·开发语言·前端
心勤则明1 小时前
Spring AI Alibaba 实战 MCP 协议
java·人工智能·spring
NGC_66112 小时前
ConcurrentHashMap1.8 多线程扩容机制
java·开发语言
东离与糖宝2 小时前
不用Python!Java+Spring AI 3.x本地RAG系统搭建实战
java·人工智能