RocketMQ的安装部署请参考官网Quick Start
RocketMQ的简单应用请参考官网github样例
本篇介绍如何通过自定义selector实现按messageQueue定向发送和接收消息
我们先看看MessageQueueSelector接口
public interface MessageQueueSelector {
MessageQueue select(final List<MessageQueue> mqs, final Message msg, final Object arg);
}
RocketMQ通过MessageQueueSelector中实现的算法来确定消息发送到哪一个队列上,RocketMQ默认提供了三种实现,分别是SelectMessageQueueByHash、SelectMessageQueueByMachineRoom、SelectMessageQueueByRandoom。MessageQueueSelector的select方法提供了三个入参,分别为消息队列集合、消息和扩展参数。本示例通过使用扩展参数来实现消息通道的定向发送和接收。
1、pom.xml引入rocketmq jar包
<!-- 引入rocketmq --> <dependency> <groupId>com.alibaba.rocketmq</groupId> <artifactId>rocketmq-client</artifactId> <version>3.2.6</version> </dependency> <!-- 提供常用的lang包工具类 --> <dependency>