快手一面:RocketMQ顺序消息如何增加吞吐量?

文章内容收录到个人网站,方便阅读:hardyfish.top/

资料分享

RocketMQ技术内幕:

RocketMQ顺序消息(Ordered Message)保证消息严格按照顺序消费,但顺序消费天然会限制消息吞吐量。

如果需要提高吞吐量,可以从以下几个维度进行优化:

一、增加队列数(合理划分队列粒度)

顺序消息在RocketMQ中是基于单个Queue顺序消费的,队列越多,并发消费能力就越强。

  • 实践:

    • 将消息按照顺序要求的业务主键进行分片(如订单号、用户ID),同一个分片的消息投递到同一个队列中,不同分片的消息可以并行消费,从而提高整体吞吐量。

例如:

java 复制代码
// 根据订单号取模,确定投递的队列
int queueNum = orderId % queueCount;

常见实践技巧:

① 提高队列数量(最常见)

  • 调整Topic的队列数量,例如从4个队列调整到8或16个。
  • 根据消息的业务标识分配到不同的Queue。
  • 单队列保证单分片顺序,多队列并行提高吞吐。
java 复制代码
// 消息发送示例(自定义消息队列选择器)
SendResult sendResult = producer.send(msg, (mqs, msg, arg) -> {
    int index = (arg.hashCode()) % mqs.size();
    return mqs.get(index);
}, orderId);

② 降低单条消息的业务处理时长

顺序消息的消费速度受限于单个消息的消费速度,因此:

  • 减少顺序消息处理过程中的耗时操作,快速提交消费结果。
  • 异步处理耗时逻辑,顺序消费只负责确认顺序并快速落盘或提交。

例如:

java 复制代码
// 快速消费,异步提交耗时任务
consumer.registerMessageListener((msgs, context) -> {
    // 同步轻量级逻辑,快速返回
    quicklySaveToDB(msgs);
    // 异步线程池处理复杂任务
    asyncExecutor.execute(() -> handleComplexTask(msgs));
    return ConsumeOrderlyStatus.SUCCESS;
});

③ 增加消费者线程数

虽然单个队列是严格串行消费,但多个Queue之间可并发消费,增加消费端线程数或消费者实例数量,提升整体吞吐。

  • 增加消费者实例数量,提升并发处理能力。
  • 合理规划Queue数量,队列数一般建议 >= 消费者实例数。

例如:

diff 复制代码
RocketMQ:
- Topic: 订单顺序消费
- Queue数量: 16 (建议适当增加Queue数)
- 消费者实例数: >= Queue数

推荐的最佳实践组合方案:

  • 发送端: 按照业务逻辑(如订单号)分片,多Queue投递。

  • 消费端:

    • 适度增加消费者线程数量。
    • 增加消费者节点(水平扩容),提高并发能力。
    • 快速消费,耗时操作异步化。

注意事项:

  • 队列越多并行越高,但维护成本也会上升,需要结合具体业务场景平衡。
  • 顺序消息消费端严禁长时间阻塞或耗时较长的操作,否则即使增加队列也无法提高吞吐量。

其实最好用redis list实现队列,因为redis list可以无限扩展,mq加队列很麻烦。

相关推荐
llwszx1 小时前
深入理解Java锁原理(一):偏向锁的设计原理与性能优化
java·spring··偏向锁
云泽野2 小时前
【Java|集合类】list遍历的6种方式
java·python·list
二进制person2 小时前
Java SE--方法的使用
java·开发语言·算法
小阳拱白菜3 小时前
java异常学习
java
程序员岳焱4 小时前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
FrankYoou4 小时前
Jenkins 与 GitLab CI/CD 的核心对比
java·docker
麦兜*4 小时前
Spring Boot启动优化7板斧(延迟初始化、组件扫描精准打击、JVM参数调优):砍掉70%启动时间的魔鬼实践
java·jvm·spring boot·后端·spring·spring cloud·系统架构
KK溜了溜了5 小时前
JAVA-springboot 整合Redis
java·spring boot·redis
大只鹅5 小时前
解决 Spring Boot 对 Elasticsearch 字段没有小驼峰映射的问题
spring boot·后端·elasticsearch
ai小鬼头5 小时前
AIStarter如何快速部署Stable Diffusion?**新手也能轻松上手的AI绘图
前端·后端·github