rocketmq中专业术语、消息队列需要解决的问题

发布时间:2021-10-11 09:39:55 作者:柒染
来源:亿速云 阅读:220

今天就跟大家聊聊有关rocketmq中专业术语、消息队列需要解决的问题,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

专业术语:

消息队列需要解决哪些问题:

1、Publish/Subscribe

发布订阅消息是消息中间件的最基本的功能,也是相对于传统的RPC而言

2、Message Priority(消息优先级)

规范中描述的优先级是指在一个消息队列中,每条消息都有不同的优先级,一般用整数来描述,优先级高的消息先投递,如果消息完全在一个内存队列中,那么在投递前可以按照优先级排序,令优先级高的先投递。 由于Rocketmq所有消息都是持久化的,所以如果按照优先级来排序,开销会非常大,因此RocketMq没有特意支持消息优先级,但是可以通过变通的方式实现类似功能,即单独配置一个优先级高的队列,和一个普通 优先级的队列,将不同优先级发送到不同的队列即可。 对于优先级问题可以归纳为2类:
1)只要达到优先级目的即可,不是严格意义上的优先级,通常将优先级划分为高、中、低,或者再多几个级别。每个优先级可以用不同的topic表示,指定不同topic来表示优先级,这种方式可以解决一部分优先级问题, 但是对业务的优先级精确性做了妥协。
2)严格的优先级,优先级用整数表示,例如:0~65535,这种优先级问题一般使用不同topic解决就非常不合适。如果让MQ解决此问题,会对MQ性能造成非常大的影响。这里要确保一点,业务上是否需要这种严格的优先级, 如果将优先级压缩成几个,对业务影响有多大?

3、Message Order(消息顺序)

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

4、Message Filter

Broker端消息过滤: 在Broker中,按照Consumer的要求做过滤,优点是减少了对于Consumer无用消息的网络传输。缺点是增加了Broker的负担,实现相对复杂
1)淘宝Notify支持多种过滤方式,包含按照消息类型过滤,灵活的语法表达式过滤
2)淘宝RocketMQ支持按照简单的MessageTag过滤,也支持按照Message Header、body进行过滤

5、Message Persistence(消息持久化)

消息中间件通常采用的几种持久化方式:
1)持久化到数据库,例如mysql
2)持久化到kv存储,例如levelDB、伯克利DB等kv存储系统
3)文件记录形式持久化,例如kafka,rocketmq
4) 对内存数据做一个持丽化镜像,例如 beanstalkd,VisiNotify
1)2)3)三种持久方式都具有将内存队列Buffer进行扩展的能力,4)只是一个内存镜像,作用是当broker挂掉重启后仍然能将之前内存的数据恢复出来
Rocketmq参考了kafka的持久化方式,充分利用Linux文件系统内存cache提高性能

6、Message Reliablity(消息的可靠性)

影响消息可靠性的几种情况: (1) Broker 正常关闭
(2) Broker 异常 Crash(崩溃)
(3) OS Crash
(4) 机器掉电,但是能立即恢复供电情况。
(5) 机器无法开机(可能是cpu、主板、内存等关键设备损坏)
(6) 磁盘设备损坏。
1)2)3)4)四种情况都属于硬件资源可立即恢复情况,Rocketmq在这四种情况下能保证消息不丢,后者丢失少量数据(依赖刷盘方式是同步还是异步)
5)6)属于单点故障,且无法恢复,一旦发生,在此单点上的消息全部丢失。RocketMQ在这两种情况下,通过异步复制,可保证99%的消息不丢,但是仍然会有极少量的消息可能丢失,通过同步双写技术可以避免单点,同步双写势必会影响性能,适合对消息可靠性要求极高的场合,例如与Money相关的应用。
rocketmq3.0版本支持同步双写

7、Low Latency Messaging(低消息延迟)

如果在消息没有堆积的情况下,在消息到大broker后,立刻到达Consumer Rocketmq使用长轮询Pull方式,可保证消息非常实时,消息实时性不低于Push

8、At Least One(至少一次)

每个消息必须投递一次。RocketMq Consumer先pull消息到本地,消费完成后,才向服务器返回ack,如果没有消费一定不回ack消息,所以Rocket MQ很好的支持此特性

9、Exactly Only One(只有一次)

1)发送消息阶段,不允许发送重复的消息
2)消费消息阶段,不允许消费重复的消息
要实现这两点,在分布式系统环境下,不可避免要产生巨大的开销,所以Rocketmq不保证此特性,要求在业务上进行去重,也就是要消费消息做到幂等。
虽然rocketmq不能严格保证不重复,但是正常情况下很少会出现重复推送、消费情况,只有网络异常,Consumer启停等异常情况下会出现消费重复。 此问题的本质原因是网络调用存在不确定性,即既不成功也不失败的第三种状态,所以才产生了消息重复性问题。

10、broker的buffer满了怎么办?

Rocketmq中没有内存buffer概念,rocketmq的队列都是持久化磁盘,数据定期清除。
对于此问题解决思路,rocketmq与其他mq不同,rocketmq的内buffer抽象成一个无限长度的队列,不管有多少数据来都能装的下,这个无限是有前提的,broker会定期删除过期的数据。例如brokr只保存3天,那么这个buffer虽然长度无限,但是3天前的数据会被从队尾删除。

11、回溯消费

回溯消费是指consumer已经消费成功的消息,由于业务上的需求需要重新消费。要支持此功能,broker再向consumer投递成功消息后,消息仍然要保留,并且重新消费一般是按照时间维度。
RocketMQ支持按照时间回溯消费,时间维度精确到毫秒,可以向前回溯,也可以向后回溯。

12、消息堆积

消息中间件的主要功能是异步解耦,迓有个重要功能是挡住前端的数据洪峰,保证后端系统的稳定性,这就要求消息中间件具有一定的消息堆积能力,消息堆积分以下两种情况:
(1)消息堆积在内存Buffer,一旦超过内存 Buffer,可以根据一定的丢弃策略来丢弃消息,如 CORBA Notification 规范中描述。适合能容忍丢弃消息的业务,这种情况消息的堆积能力主要在于内存 Buffer 大小,而且消息堆积后,性能下降不会太大,因为内存中数据多少对于对外提供的访问能力影响有限。
(2)消息堆积到持久化存储系统中,例如DB,KV存储,文件记录形式。对于消息不能在内存 Cache 命中时,要不可避免的访问磁盘,会产生大量读 IO,读 IO 的吞吐量直接决定了消息堆积后的访问能力。
评估消息堆积能力主要有以下四点:
(1). 消息能堆积多少条,多少字节?即消息的堆积容量。
(2). 消息堆积后,发消息的吞吐量大小,是否会受堆积影响?
(3). 消息堆积后,正常消费的Consumer是否会受影响?
(4). 消息堆积后,访问堆积在磁盘的消息时,吞吏量有多大?

13、分布式事务

已知的几个分布式事务规范,如:XA,JTA。其中XA规范被各大数据库厂商广泛支持。如:Orcal、Mysql等。
XA 是一个两阶段提交协议,该协议分为以下两个阶段: 第一阶段:事务协调器要求每个涉及到事务的数据库预提交(precommit)此操作,并反映是否可以提交.
第二阶段:事务协调器要求每个数据库提交数据。 Rocketmq实现事务的方式没有通过kv存储,而是通过offset方式来访问消息。存在一个显著缺陷,就是用过offset更改数据,会令系统的脏页过多,需要特别的关注。

14、定时消息

定时消息是指消息发送到broker后,不能立刻被Conusmer消费,要到特定的时间点或者等待特定的时间后才能被消费。 Rocketmq支持定时消息,但是不自持任意时间精度,支持特定的level,例如定时5s,10s,1m等。

15、消息重试

Consumer消费消息失败后,要提供一种重试机制,令消息再消费一次。 消费消息失败通常认为有以下几种情况:
1)由于消息本身原因,例如反序列化失败,消息数据本身无法处理。这种错误通常需要跳过这条消息,再消费其他消息,而这条失败的消息即使立刻重试消费,99%也不成功所以最好提供一种定时重试机制,即过10s后再重试
2)由于依赖的下游应用服务不可用,例如:db连接不可用,外系网络不可达等。遇到这种情况,即使跳过当前失败的消息,消费其他消息同样也会报错。这种情况建议sleep 30秒再消费下一条消息,这样减轻broker重试消息的压力。

看完上述内容,你们对rocketmq中专业术语、消息队列需要解决的问题有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

推荐阅读:
  1. 运营中的专业术语介绍
  2. 运营入门需要懂得的专业术语

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

rocketmq

上一篇:如何实现dos批量替换当前目录后缀名

下一篇:如何使用DataAdapter执行批量更新

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》