详细介绍MessageQueueSelector
一、MessageQueueSelector 详解
MessageQueueSelector 是 RocketMQ 提供的一个接口,用于自定义消息发送时的队列选择策略。 通过实现该接口,
开发者可以控制消息被发送到 Topic 的哪个队列(MessageQueue),从而支持 顺序消息、负载均衡、业务隔离 等高级场景
1、接口定义

2、使用场景
A、顺序消息(关键场景)
需求:同一业务键(如订单 ID)的消息必须发送到同一队列,保证消费顺序
实现:
// 示例:按订单ID哈希选择队列,确保同一订单的消息进入同一队列
SendResult result = producer.send(msg, new MessageQueueSelector() {
@Override
public MessageQueue select(List<MessageQueue> queues, Message msg, Object arg) {
String orderId = (String) arg; // arg 传入订单ID
int index = Math.abs(orderId.hashCode()) % queues.size();
return queues.get(index);
}
}, "订单123"); // 将订单ID作为 arg 传入
B、负载均衡优化
需求:避免热点队列,根据业务特征分散消息
实现:
// 示例:按用户ID轮询选择队列
SendResult result = producer.send(msg, (mqs, msg, arg) -> {
long userId = (Long) arg;
return mqs.get((int) (userId % mqs.size()));
}, 12345L);
C、业务隔离
需求:不同业务类型的消息路由到不同队列
实现:
// 示例:按消息标签(Tag)选择队列
SendResult result = producer.send(msg, (mqs, msg, arg) -> {
String tag = msg.getTags();
if ("PAYMENT".equals(tag)) {
return mqs.get(0); // 支付消息固定发到队列0
} else {
return mqs.get(1); // 其他消息发到队列1
}
}, null);
二、核心注意事项
1、队列数量稳定性
问题:如果动态增加 Topic 的队列数,可能导致哈希结果不一致,破坏顺序消息
解决:
提前规划队列数(如固定 16 个队列),避免扩容
如需扩容,需停机迁移或使用一致性哈希算法
2、参数传递
- arg 的作用:通过 send() 方法的第三个参数传递业务标识(如订单ID),在 select() 中使用

3、异常处理
- 空队列问题:如果 queues 为空(如 Topic 未创建),需抛出异常或降级处理

4、内置实现类
RocketMQ 提供了几个常用的内置选择器:

使用示例:

5、完整代码示例

6、最佳实践
顺序消息:使用业务键(如订单ID)作为 arg,确保相同键的消息进入同一队列。
性能优化:避免在 select() 中执行复杂计算(如数据库查询)。
监控:记录队列选择分布,避免数据倾斜(如某些队列压力过大)。
详细介绍MessageQueueSelector的更多相关文章
- [No0000A7]批处理经常用到的变量及批处理>NUL详细介绍
绝对路径是指调用绝对的程序位置的路径,例如: start C:\Windows\test.exe 相对路径是文件改变路径以后还会按照变量的路径所在位置去调用,例如: start %WINDIR%\te ...
- linux配置网卡IP地址命令详细介绍及一些常用网络配置命令
linux配置网卡IP地址命令详细介绍及一些常用网络配置命令2010-- 个评论 收藏 我要投稿 Linux命令行下配置IP地址不像图形界面下那么方 便,完全需要我们手动配置,下面就给大家介绍几种配置 ...
- _MSC_VER详细介绍
_MSC_VER详细介绍 转自:http://www.cnblogs.com/braver/articles/2064817.html _MSC_VER是微软的预编译控制. _MSC_VER可以分解为 ...
- php CGI、Fastcgi、PHP-FPM的详细介绍与之间的关系
以下PHP CGI.Fastcgi.PHP-FPM的一些信息归纳和汇总----->详细介绍与之间的关系 一:CGI是干嘛的?CGI是为了保证web server传递过来的数据是标准格式的 web ...
- RabbitMQ消息队列(一): Detailed Introduction 详细介绍
http://blog.csdn.net/anzhsoft/article/details/19563091 RabbitMQ消息队列(一): Detailed Introduction 详细介绍 ...
- doT.js详细介绍
doT.js详细介绍 doT.js特点是快,小,无依赖其他插件. 官网:http://olado.github.iodoT.js详细使用介绍 使用方法:{{= }} for interpolati ...
- Linux截屏工具scrot用法详细介绍
Scrot是Linux命令行中使用的截图工具,能够进行全屏.选取等操作,下面小编将针对Scrot截图工具的用法给大家做个详细介绍,通过操作实例来学习Scrot的使用. 在Linux中安装Scrot ...
- Oracle Merge into 详细介绍
Oracle Merge into 详细介绍 /*Merge into 详细介绍MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句.通过MERGE语句,根据一张表或子查 ...
- cPage分页详细介绍
asp.net中各种数据控件,datalist.gridview.Repeater等分页是最常用的功能,几乎任何一个B/S项目,无论是系统还是网站都会用到.分页时,读取整个数据,直接绑定到控件,都可以 ...
- 【转载】硬盘MBR详细介绍
原文地址:http://blog.chinaunix.net/uid-15007890-id-106892.html 硬盘MBR详细介绍 硬盘是现在计算机上最常用的存储器之一.我们都知道,计 ...
随机推荐
- 项目PMP之六项目进度管理
项目PMP之六--项目进度管理 一.定义:用于沟通和管理相关方期望的工具,可作为报告绩效的基础,说明项目的交付时间和方式 迭代型进度计划(敏捷模式):接受存在未完成项,滚动式规划管理 按需进度计划 ...
- C语言实现高阶阶乘(1000的阶乘C语言实现)
由于C语言的变量的大小的限制,使用已有变量无法保存阶乘结果,所以使用数组保存结果,从而使得无法保存的结果得以保存. #include <stdio.h> void Print_Factor ...
- Kotlin:【Map集合】集合创建、集合遍历、元素增加
to本身是一个函数
- thewall靶机
includes.php 内有文件读取漏洞 一开始是想着直接用为协议写入一句话木马但是后来发现不行 因为他的文件读取方式长这样 点击查看代码 <?php include ('/var/www/h ...
- CRISP-DM的应用与理解
本文分享自天翼云开发者社区<CRISP-DM的应用与理解>,作者:吴****嫄 CRISP-DM是一个数据挖掘项目规划的开放标准流程框架模型,主要分为业务理解.数据理解.数据准备.建模.评 ...
- Whois 收集
Whois 收集 Whois是什么 Whois(读作"Who is")是一个标准的互联网协议,主要用于查询域名的注册信息,包括域名所有人.注册商.注册时间.过期时间等详细信息.简单 ...
- oracle数据库 关闭归档模式
-- 1. 连接到数据库 CONNECT / AS SYSDBA; -- 2. 确保数据库处于mount状态 SHUTDOWN IMMEDIATE; STARTUP MOUNT; -- 3. ...
- Iceberg调研报告-腾讯数据集成工具报告
标题 测试报告 背景目标 大航海databus任务在合并阶段费资源,且大表执行时间较长,期望缩短同步时间可以10分钟抽10亿条数据.数据同步需要先建表,再建任务,配置不方便. 结论 在满足配置时可以达 ...
- 百万架构师第四十课:RabbitMq:RabbitMq-工作模型与JAVA编程|JavaGuide
来源:https://javaguide.net RabbitMQ 1-工作模型与Java编程 课前准备 预习资料 Windows安装步骤 Linux安装步骤 官网文章中文翻译系列 环境说明 操作系统 ...
- min-max 容斥(最值反演)学习笔记
min-max 容斥,又名最值反演(我其实更喜欢后面这个名字),是一种常用的反演思想. 引入 在皇后游戏一题中,我们曾经证明过 \(\max(a,b)-a-b=-\min(a,b)\). 我们尝试推广 ...