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. 典型故障处理

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

相关推荐
坊钰1 分钟前
【Rabbit MQ】Rabbit MQ 的结构详解,传输机制!!!
java·rabbitmq
Psycho_MrZhang2 分钟前
Claude高质量产出
java·服务器·网络
spencer_tseng3 小时前
Stream not available [SysDictDataMapper.xml]
xml·java
蒸蒸yyyyzwd8 小时前
cpp对象模型学习笔记1.1-2.8
java·笔记·学习
程序员徐师兄9 小时前
Windows JDK11 下载安装教程,适合新手
java·windows·jdk11 下载安装·jdk11 下载教程
RANCE_atttackkk9 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
五岳9 小时前
DTS按业务场景批量迁移阿里云MySQL表实战(下):迁移管理平台设计与实现
java·应用·dts
zhougl99610 小时前
Java 所有关键字及规范分类
java·开发语言
Python 老手10 小时前
Python while 循环 极简核心讲解
java·python·算法
java1234_小锋10 小时前
Java高频面试题:MyISAM索引与InnoDB索引的区别?
java·开发语言