RocketMQ和kafka区别
2021-07-24 15:32:42 15 举报
AI智能生成
RocketMQ和kafka区别
作者其他创作
大纲/内容
数据可靠性
RocketMQ支持异步实时刷盘,同步刷盘,同步Replication,异步Replication<br>Kafka使用异步刷盘方式,异步Replication<br>
性能对比
Kafka单机写入TPS约在百万条/秒,消息大小10个字节<br>RocketMQ单机写入TPS单实例约7万条/秒,单机部署3个Broker,可以跑到最高12万条/秒,消息大小10个字节
单机支持的队列数
Kafka单机超过64个队列/分区,Load会发生明显的飙高现象,队列越多,load越高,发送消息响应时间变长<br>RocketMQ单机支持最高5万个队列,Load不会发生明显变化
队列多有什么好处?<br><br>单机可以创建更多Topic,因为每个Topic都是由一批队列组成<br>Consumer的集群规模和队列数成正比,队列越多,Consumer集群可以越大
消息投递实时性
Kafka使用短轮询方式,实时性取决于轮询间隔时间<br>RocketMQ使用长轮询,同Push方式实时性一致,消息的投递延时通常在几个毫秒。
消费失败重试
Kafka支持消费重试次数、间隔<br>RocketMQ消费失败支持定时重试,每次重试间隔时间顺延
严格的消息顺序
Kafka支持消息顺序,但是一台Broker宕机后,就会产生消息乱序<br>RocketMQ支持严格的消息顺序,在顺序消息场景下,一台Broker宕机后,发送消息会失败,但是不会乱序
定时消息
Kafka不支持定时消息<br>RocketMQ支持两类定时消息<br>开源版本RocketMQ仅支持定时Level<br>阿里云ONS支持定时Level,以及指定的毫秒级别的延时时间<br>
分布式事务消息
Kafka不支持分布式事务消息<br>阿里云ONS支持分布式定时消息,未来开源版本的RocketMQ也有计划支持分布式事务消息
消息查询
Kafka不支持消息查询<br>RocketMQ支持根据Message Id查询消息,也支持根据消息内容查询消息(发送消息时指定一个Message Key,任意字符串,例如指定为订单Id)
消息回溯
Kafka理论上可以按照Offset来回溯消息<br>RocketMQ支持按照时间来回溯消息,精度毫秒,例如从一天之前的某时某分某秒开始重新消费消息
消费并行度
Kafka的消费并行度依赖Topic配置的分区数,如分区数为10,那么最多10台机器来并行消费(每台机器只能开启一个线程),或者一台机器消费(10个线程并行消费)。即消费并行度和分区数一致。<br><br>RocketMQ消费并行度分两种情况<br><br>顺序消费方式并行度同Kafka完全一致<br>乱序方式并行度取决于Consumer的线程数,如Topic配置10个队列,10台机器消费,每台机器100个线程,那么并行度为1000。
消息轨迹
Kafka不支持消息轨迹<br>阿里云ONS支持消息轨迹
开发语言友好性
Kafka采用Scala编写<br>RocketMQ采用Java语言编写
Broker端消息过滤
Kafka不支持Broker端的消息过滤<br>RocketMQ支持两种Broker端消息过滤方式<br>根据Message Tag来过滤,相当于子topic概念<br>向服务器上传一段Java代码,可以对消息做任意形式的过滤,甚至可以做Message Body的过滤拆分
消息堆积能力
理论上Kafka要比RocketMQ的堆积能力更强,不过RocketMQ单机也可以支持亿级的消息堆积能力,我们认为这个堆积能力已经完全可以满足业务需求。
0 条评论
下一页