目录
第一节:介绍
顺序消息含义介绍
原理解析
第二节:顺序消息-生产者和消息者步骤说明
顺序消息生产者代码实现步骤
顺序消息消费者代码实现步骤
第三节:顺序消息生产者
效果:
第四节:顺序消息消费者
效果:
第一节:介绍
======
顺序消息含义介绍
顺序消息指的是可以按照消息的发送顺序来消费(FIFO)。RocketMQ可以严格的保证消息有序,可以分为分区有序或者全局有序。
原理解析
在默认的情况下消息发送会采取Round Robin轮询方式把消息发送到不同的queue(分区队列);
而消费消息的时候从多个queue上拉取消息,这种情况发送和消费是不能保证顺序。
但是如果控制发送的顺序消息只依次发送到同一个queue中,消费的时候只从这个queue上依次拉取,则就保证了顺序。如下图所示:
当发送和消费参与的queue只有一个,则是全局有序;如果多个queue参与,则为分区有序,即相对每个queue,消息都是有序的。
第二节:顺序消息-生产者和消息者步骤说明
====================
顺序消息生产者代码实现步骤
1.创建消息生产者producer并制定生产者组名
2.指定Nameserver地址
3.启动producer
4.创建消息对象,指定主题Topic、Tag和消息体
5.发送消息,选择的send方法有三个参数:
-
* 参数一:消息对象
-
* 参数二:消息队列的选择器
-
* 参数三:选择队列的业务标识 6.关闭生产者producer
顺序消息消费者代码实现步骤
1.创建消费者Consumer,制定消费者组名
2.指定Nameserver地址
3.订阅主题Topic和Tag
4.设置回调函数,处理消息:与普通消息的差别,这里用的是MessageListenerOrderly
5.启动消费者consumer
注意:消费者的 Topic 和 Tag 需要和生产者保持一致
第三节:顺序消息生产者
===========
public class Producer {
public static void main(String[] args) throws Exception {
// 1.创建消息生产者producer,并制定生产者组名
DefaultMQProducer producer = new DefaultMQProducer(“demo_producer_order_group”);
// 2.指定Nameserver地址
producer.setNamesrvAddr(“192.168.88.131:9876”);
// 3.启动producer
producer.start();
System.out.println(“生产者启动”);
for (int i = 0; i < 20; i++) {
// 4.创建消息对象,指定主题Topic、Tag和消息体
Message msg = new Message(“Topic_order_demo”, “Tag_order_demo”,
(“Hello 虚竹,这是顺序消息” + i).getBytes(RemotingHelper.DEFAULT_CHARSET));
// 5.发送消息
/**
-
参数一:消息对象
-
参数二:消息队列的选择器
-
参数三:选择队列的业务标识
*/
SendResult result = producer.send(msg, new MessageQueueSelector() {
/**
-
@param mqs:队列集合
-
@param msg:消息对象
-
@param arg:业务标识的参数
-
@return
*/
@Override
public MessageQueue select(List mqs, Message msg, Object arg) {
Integer index = (Integer) arg;
return mqs.get(index);
}
}, 1);
System.out.println(“发送结果:” + msg.toString());
}
// 6.关闭生产者producer
producer.shutdown();
System.out.println(“生产者关闭”);
}
}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/e68787de2bfe6f797bae92320b1ef08b.jpeg)
最后
我还为大家准备了一套体系化的架构师学习资料包以及BAT面试资料,供大家参考及学习
已经将知识体系整理好(源码,笔记,PPT,学习视频)
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
资料,供大家参考及学习
已经将知识体系整理好(源码,笔记,PPT,学习视频)
[外链图片转存中…(img-AViEDH5T-1713380446709)]
[外链图片转存中…(img-Ss6PxKrw-1713380446710)]
[外链图片转存中…(img-oqW2fuXP-1713380446710)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!