rocketMQ之关键特性

RocketMQ提供多种关键特性,包括订阅与发布、负载均衡、消息顺序(全局与分区顺序)、消息过滤、消息可靠性、消息必须投递一次、回溯消费、事务消息、定时消息、消息重试和消息重投、流量控制以及死信队列。消息顺序保证了消息的消费顺序,事务消息实现了分布式事务的一致性,而流量控制和死信队列则确保系统稳定性和异常消息的处理。
摘要由CSDN通过智能技术生成

rocketMQ之特性


分布式消息系统作为实现分布式系统可扩展、可伸缩的关键组件,需要具有高吞吐量、高可用等特点


前言

上篇文章
rocketMQ之基本概念


特性

订阅与发布

消息的发布是指某个生产者向某个topic发送消息;消息的订阅是指某个消费者关注了某个topic中
带有某些tag的消息,进而从该topic消费数据。

负载均衡

Producer轮询某topic下的所有队列的方式来实现发送方的负载均衡。随机轮询队列(Roundbin),全局维护一个自增id,发送一次消息自增一次,与queueSize取模得出发送队列。
在这里插入图片描述
消费端会通过RebalanceService线程,10秒钟做一次基于topic下的所有队列负载:遍历Consumer下的所有topic,然后根据topic订阅所有的消息获取同一topic和Consumer Group下的所有Consumer,然后根据具体的分配策略来分配消费队列,分配的策略包含:平均分配、消费端配置等
在这里插入图片描述
在rocketmq里,consumer被分为2类:MQPullConsumer和MQPushConsumer,其实本质都是拉模式(pull),即consumer轮询从broker拉取消息。区别是:push方式里,consumer把轮询过程封装了,并注册MessageListener监听器,取到消息后,唤醒MessageListenerconsumeMessage()来消费,对用户而言,感觉消息是被推送过来的。pull方式里,取消息的过程需要用户自己写,首先通过打算消费的Topic拿到MessageQueue的集合,遍历MessageQueue集合,然后针对每个MessageQueue批量取消息,一次取完后,记录该队列下一次要取的开始offset,直到取完了,再换另一个MessageQueue


消息顺序

在这里插入图片描述

消息有序指的是一类消息消费时,能按照发送的顺序来消费。例如:一个订单产生了三条消息分别是订单创建、订单付款、订单完成。消费时要按照这个顺序消费才能有意义,但是同时订单之间是可以并行消费的。RocketMQ可以严格的保证消息有序。

顺序消息分为全局顺序消息与分区顺序消息,全局顺序是指某个Topic

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值