首页 > 其他分享 >招行面试:RocketMQ、Kafka、RabbitMQ,如何选型?

招行面试:RocketMQ、Kafka、RabbitMQ,如何选型?

时间:2025-01-07 10:11:47浏览次数:10  
标签:场景 RabbitMQ Kafka 消息 RocketMQ 尼恩

本文原文链接

文章很长,且持续更新,建议收藏起来,慢慢读!疯狂创客圈总目录 博客园版 为您奉上珍贵的学习资源 :

免费赠送 :《尼恩Java面试宝典》 持续更新+ 史上最全 + 面试必备 2000页+ 面试必备 + 大厂必备 +涨薪必备
免费赠送 :《尼恩技术圣经+高并发系列PDF》 ,帮你 实现技术自由,完成职业升级, 薪酬猛涨!加尼恩免费领
免费赠送 经典图书:《Java高并发核心编程(卷1)加强版》 面试必备 + 大厂必备 +涨薪必备 加尼恩免费领
免费赠送 经典图书:《Java高并发核心编程(卷2)加强版》 面试必备 + 大厂必备 +涨薪必备 加尼恩免费领
免费赠送 经典图书:《Java高并发核心编程(卷3)加强版》 面试必备 + 大厂必备 +涨薪必备 加尼恩免费领

免费赠送 资源宝库: Java 必备 百度网盘资源大合集 价值>10000元 加尼恩领取


招行面试:RocketMQ、Kafka、RabbitMQ,如何选型?

尼恩特别说明: 尼恩的文章,都会在 《技术自由圈》 公号 发布, 并且维护最新版本。 如果发现图片 不可见, 请去 《技术自由圈》 公号 查找

尼恩说在前面

在45岁老架构师 尼恩的读者交流群(50+)中,最近有小伙伴拿到了一线互联网企业如得物、阿里、滴滴、极兔、有赞、希音、百度、网易、美团、蚂蚁、得物的面试资格,遇到很多很重要的相关面试题:

问题5:如何根据应用场景选择合适的消息中间件?

最近有小伙伴面试招行, 问到了相关的面试题。

小伙伴没有系统的去梳理和总结,所以支支吾吾的说了几句,面试官不满意,面试挂了。

所以,尼恩给大家做一下系统化、体系化的梳理,使得大家内力猛增,可以充分展示一下大家雄厚的 “技术肌肉”,让面试官爱到 “不能自已、口水直流”,然后实现”offer直提”。

当然,这道面试题,以及参考答案,也会收入咱们的 《尼恩Java面试宝典PDF》V175版本,供后面的小伙伴参考,提升大家的 3高 架构、设计、开发水平。

《尼恩 架构笔记》《尼恩高并发三部曲》《尼恩Java面试宝典》的PDF,请到文末公号【技术自由圈】获取

招商银行的高阶Java后端面试真题

被狠狠拷打了,问的人都懵了。项目场景题太难了,不好好准备,真的答不出!

image.png

尼恩将给出全部答案:

1.如何让系统抗住双十一的预约抢购活动?

45岁资深老架构师尼恩的参考答案,点此查看

2.如何从零搭建10万级QPS大流量、高并发优惠券系统?

45岁资深老架构师尼恩的参考答案,点此查看

3.百万级别数据的 Excel 如何快速导入到数据

45岁资深老架构师尼恩的参考答案,点此查看

4.如何设计一个支持万亿GB网盘实现秒传与限速的系统?

45岁资深老架构师尼恩的参考答案,点此查看

5.如何根据应用场景选择合适的消息中间件?

本文

6.如何提升 RocketMQ 顺序消费性能?

即将发布。

7.使用分布式调度框架该考虑哪些问题?

即将发布。

9.如何让系统抗住双十一的预约抢购活动?

45岁资深老架构师尼恩的参考答案,点此查看

10.问 :如何解决高并发下的库存抢购超卖少买?

即将发布。

11.为什么高并发下数据写入不推荐关系数据?

45岁资深老架构师尼恩的参考答案,点此查看

12.如果让你设计一个分布式链路跟踪系统?

即将发布。

前几天 尼恩给一个 小伙伴改造过一个 100wtps 链路跟踪平台简历, 非常NB, 牛到暴表。

本文目录

招行面试:如何根据应用场景选择合适的消息中间件?

分布式、微服务、高并发架构中,消息队列(Message Queue,简称MQ)扮演着至关重要的角色。

消息队列用于实现系统间的异步通信、解耦、削峰填谷等功能。

目前常见的MQ实现包括RabbitMQ、RocketMQ和Kafka。

RocketMQ、Kafka、RabbitMQ如何选择?

接下来,尼恩给大家 对比RocketMQ和RabbitMQ和Kafka,帮助大家在技术选型时做出最佳的技术选型。

三大MQ的简单对比

特性 RabbitMQ RocketMQ Kafka
公司/社区 Rabbit 阿里 Apache
开发语言 Erlang Java Scala & Java
协议支持 AMQP,XMPP,SMTP,STOMP 自定义协议 自定义协议
可用性
单机吞吐量 一般 非常高
消息延迟 微秒级 毫秒级 毫秒以内
消息可靠性 一般

第一大mq:RabbitMQ

RabbitMQ是由Pivotal开发的开源消息队列系统,基于Erlang语言开发,采用 AMQP(Advanced Message Queuing Protocol)协议。

image.png

以下是RabbitMQ的一些主要特点:

RabbitMQ优点

  • 高可靠性:RabbitMQ支持消息持久化、确认机制和死信队列等功能,确保消息不会丢失。
  • 灵活的路由机制:支持多种交换机类型(如直连交换机、主题交换机、扇出交换机等),能够灵活地根据业务需求路由消息。
  • 丰富的插件:RabbitMQ拥有丰富的插件支持,如管理界面插件、监控插件等,方便运维和管理。
  • 低延迟:在低延迟消息传递场景中表现出色,适用于实时性要求较高的业务场景。

RabbitMQ缺点

  • 性能瓶颈:在高并发和大吞吐量场景下,RabbitMQ可能会遇到性能瓶颈,需要进行性能调优。
  • 扩展性:虽然支持集群模式,但在大规模集群下的扩展性不如Kafka和RocketMQ。

RabbitMQ使用场景:

适用于中小型企业的一般消息队列需求,如异步任务处理、系统解耦、消息通知等场景 。

第二大mq:Kafka

Apache Kafka是一个分布式流处理平台,最初由LinkedIn开发,并于2011年开源。

Kafka的设计初衷是用于高吞吐量、低延迟的数据流处理和实时数据管道。

Kafka的核心组件包括生产者、消费者、主题和分区。

image.png

Kafka优点:

  • 高吞吐量:Kafka能够处理每秒数百万条消息,适合大规模数据流处理。
  • 水平扩展性:通过分区机制,Kafka可以轻松扩展,支持大规模分布式部署。
  • 持久化存储:Kafka将消息持久化到磁盘,确保数据的可靠性和持久性。
  • 高可用性:通过复制机制,Kafka能够在节点故障时继续提供服务。
  • 低延迟:Kafka设计为低延迟系统,适合实时数据处理。

Kafka缺点:

  • 复杂性:Kafka的部署和管理相对复杂,需要专业知识和经验。
  • 资源占用:Kafka对硬件资源要求较高,特别是磁盘和网络带宽。
  • 延迟一致性:Kafka采用最终一致性模型,可能导致短暂的不一致。

Kafka使用场景:

  • 实时数据处理:需要处理高吞吐量、低延迟的数据流,如实时日志分析、实时监控和实时推荐系统。
  • 大数据管道:构建数据管道,将数据从不同来源高效传输到数据湖或数据仓库。
  • 事件驱动架构:实现事件驱动的微服务架构,支持事件的发布和订阅。
  • 日志聚合:集中收集和处理分布式系统的日志数据,进行统一分析和监控。

第三大mq:RocketMQ

RocketMQ是阿里巴巴开源的一款分布式消息队列系统,采用Java语言开发,具备高性能、高可靠性和高可用性的特点。2016年捐赠给Apache基金会。

RocketMQ的设计目标是高可靠性、高性能和高可用性,支持分布式事务和顺序消息等高级特性。

RocketMQ的核心组件包括生产者、消费者、主题和队列。

image.png

以下是RocketMQ的一些主要特点:

RocketMQ优点

  • 高吞吐量:RocketMQ设计之初就考虑到了高吞吐量的需求,适用于大规模的消息传输场景。
  • 分布式架构:天然支持分布式架构,易于横向扩展,适用于大规模集群部署。
  • 消息顺序:支持严格的消息顺序,满足对消息顺序性有严格要求的业务场景。
  • 灵活的消费模式:支持多种消费模式,包括广播消费和集群消费。
  • 丰富的功能:支持定时消息、延迟消息、死信队列和批量消息等高级功能,满足复杂业务需求。

RocketMQ缺点

  • 社区活跃度:是国产的消息中间件,有活跃的国内社区支持,相关的技术文档和案例较为丰富,同时也得到了阿里巴巴等企业的技术支持。
  • 学习成本:相比RabbitMQ,RocketMQ的配置和使用相对复杂,学习成本较高。
  • 生态系统:虽然正在快速发展,但RocketMQ的生态系统和社区支持相比RabbitMQ和Kafka还有一定差距。

RocketMQ使用场景:

  • 金融交易系统:需要高可靠性和顺序消息处理的金融交易系统。
  • 电商平台:处理高并发订单和支付消息,确保消息的可靠传递和顺序处理。
  • 分布式事务:支持分布式事务的业务场景,如跨服务的事务管理。
  • 消息通知系统:实现高可靠性的消息通知和广播,如短信、邮件通知系统。

为什么阿里会自研RocketMQ?

(1)Kafka的业务应用场景主要定位于日志传输;对于复杂业务支持不够

(2)阿里很多业务场景对数据可靠性、数据实时性、消息队列的个数等方面的要求很高。

kafka针对海量数据,但是对数据的正确度要求不是十分严格。

而阿里巴巴中用于交易相关的事情较多,对数据的正确性要求极高,Kafka不合适

(3)当业务成长到一定规模,采用开源方案的技术成本会变高.

开源方案无法满足业务的需要;旧版本、自开发代码与新版本的兼容都可能是问题;运维角度,Kafka使用 scala 编写,而阿里是java系。Kafka 的后续维护是个问题。

(4)阿里在团队、成本、资源投入等方面约束性条件几乎没有.

RocketMQ、Kafka、RabbitMQ的全面对比和PK

RocketMQ、Kafka、RabbitMQ 都是常用的消息中间件 ,可从性能、功能、可靠性、运维复杂度等方面进行全面PK:

三大mq 性能PK

  • RocketMQ

10Wtps 级别。

采用分布式架构,能支持高并发和低延迟的消息处理,在大规模数据处理场景下表现稳定,消息发送和消费的性能较高,适合对性能要求较高的分布式系统。

  • Kafka

10Wtps 级别。

以高吞吐量著称,擅长处理大规模的消息流数据,适用于对实时性要求高、数据量大的场景,如日志收集、实时数据处理等。

  • RabbitMQ

1Wtps 级别。

性能相对较弱,在处理大量消息时可能会出现性能瓶颈,但在小规模场景下表现良好,能满足一般的消息队列需求。

三大mq 功能PK

  • RocketMQ

支持事务消息、顺序消息、广播消息等高级特性,能满足一些对消息处理有严格要求的业务场景,如电商订单处理等。

  • Kafka

具有强大的分区、副本和多副本机制,能保证数据的高可用性和可靠性,同时支持消息的批量处理和压缩,提高了数据传输效率。

  • RabbitMQ

支持多种消息队列模式,如点对点、发布订阅、路由等,提供了丰富的插件生态,可通过插件扩展功能,如实现消息的延迟发送等。

三大mq 可靠性 PK

  • RocketMQ
  • 采用分布式架构和多副本机制,保证了数据的可靠性和高可用性,支持消息的持久化和故障转移,能在节点故障时快速恢复消息处理。
  • Kafka
  • 通过多副本机制和分布式存储,确保数据的可靠性和容错性,能自动进行副本的选举和故障转移,保证消息不丢失。
  • RabbitMQ
  • 支持消息的持久化和镜像队列等机制,可保证消息在节点故障时不丢失,但在大规模集群环境下,维护其可靠性的复杂度相对较高。

三大mq 运维 PK

  • RocketMQ

运维相对简单,提供了可视化的管理控制台,方便进行集群管理、消息监控等操作,对运维人员的技术要求相对较低。

  • Kafka

集群部署和运维相对复杂,需要对分布式系统和存储有一定的了解,涉及到多个组件的配置和管理,但有一些开源的运维工具可降低运维难度。

  • RabbitMQ

运维复杂度适中,提供了管理界面,但在集群扩展和性能调优方面需要一定的技术经验,对运维人员的要求较高。

三大mq 社区生态 PK

  • RocketMQ

是国产的消息中间件,有活跃的国内社区支持,相关的技术文档和案例较为丰富,同时也得到了阿里巴巴等企业的技术支持。

  • Kafka

拥有庞大的开源社区,有丰富的文档、插件和周边工具,生态系统成熟,在大数据领域有广泛的应用和支持。

  • RabbitMQ

社区活跃度高,有大量的开源插件和工具可供使用,商业支持也较为完善,能为企业提供专业的技术服务。

三大mq 支持的队列数 PK

大型业务场景, Kafka 单机超过64个队列/分区,消息发送性能降低严重,需要进行深度定制和改造 ,京东就改造过;

大型业务场景, RocketMQ 单机支持最高5万个队列,而且 性能稳定

RabbitMQ 是企业级的mq,大型的业务场景很少人使用。

三大mq 适用场景 PK

  • RocketMQ:适用于对消息可靠性、顺序性要求高,以及有分布式事务需求的场景,如金融交易、电商订单处理、分布式事务协调等。
  • Kafka:适合用于大数据处理、实时数据流式处理、日志收集与分析等对吞吐量要求高、实时性强、消息可靠性要求低的场景。
  • RabbitMQ:适用于中小型企业的一般消息队列需求,如异步任务处理、系统解耦、消息通知等场景,尤其适合对消息处理逻辑复杂、需要灵活配置的情况。

三大mq 如何选择?

尼恩建议大家,围绕RocketMQ 和 Kafka做选型:

  • 消息可靠场景、队列数量庞大的场景,选择 RocketMQ
  • 消息可靠场景、队列数量较少的场景,选择 Kafka

说在最后:有问题找老架构取经‍

只要按照上面的 尼恩团队梳理的 方案去作答, 你的答案不是 100分,而是 120分。 面试官一定是 心满意足, 五体投地。

按照尼恩的梳理,进行 深度回答,可以充分展示一下大家雄厚的 “技术肌肉”,让面试官爱到 “不能自已、口水直流”,然后实现”offer直提”。

在面试之前,建议大家系统化的刷一波 5000页《尼恩Java面试宝典PDF》,里边有大量的大厂真题、面试难题、架构难题。

很多小伙伴刷完后, 吊打面试官, 大厂横着走。

在刷题过程中,如果有啥问题,大家可以来 找 40岁老架构师尼恩交流。

另外,如果没有面试机会, 可以找尼恩来改简历、做帮扶。前段时间,刚指导一个小伙 暴涨200%(涨2倍),29岁/7年/双非一本 , 从13K一次涨到 37K ,逆天改命

狠狠卷,实现 “offer自由” 很容易的, 前段时间一个武汉的跟着尼恩卷了2年的小伙伴, 在极度严寒/痛苦被裁的环境下, offer拿到手软, 实现真正的 “offer自由” 。

技术自由的实现路径:

实现你的 架构自由:

吃透8图1模板,人人可以做架构

10Wqps评论中台,如何架构?B站是这么做的!!!

阿里二面:千万级、亿级数据,如何性能优化? 教科书级 答案来了

峰值21WQps、亿级DAU,小游戏《羊了个羊》是怎么架构的?

100亿级订单怎么调度,来一个大厂的极品方案

2个大厂 100亿级 超大流量 红包 架构方案

… 更多架构文章,正在添加中

实现你的 响应式 自由:

响应式圣经:10W字,实现Spring响应式编程自由

这是老版本 《Flux、Mono、Reactor 实战(史上最全)

实现你的 spring cloud 自由:

Spring cloud Alibaba 学习圣经》 PDF

分库分表 Sharding-JDBC 底层原理、核心实战(史上最全)

一文搞定:SpringBoot、SLF4j、Log4j、Logback、Netty之间混乱关系(史上最全)

实现你的 linux 自由:

Linux命令大全:2W多字,一次实现Linux自由

实现你的 网络 自由:

TCP协议详解 (史上最全)

网络三张表:ARP表, MAC表, 路由表,实现你的网络自由!!

实现你的 分布式锁 自由:

Redis分布式锁(图解 - 秒懂 - 史上最全)

Zookeeper 分布式锁 - 图解 - 秒懂

实现你的 王者组件 自由:

队列之王: Disruptor 原理、架构、源码 一文穿透

缓存之王:Caffeine 源码、架构、原理(史上最全,10W字 超级长文)

缓存之王:Caffeine 的使用(史上最全)

Java Agent 探针、字节码增强 ByteBuddy(史上最全)

实现你的 面试题 自由:

4800页《尼恩Java面试宝典 》 40个专题

免费获取11个技术圣经PDF:

标签:场景,RabbitMQ,Kafka,消息,RocketMQ,尼恩
From: https://www.cnblogs.com/crazymakercircle/p/18656996

相关文章

  • Kafka详解 ④ | Kafka中的数据不丢失机制与配置文件说明
    目录1、Kafka中的数据不丢失机制1.1、生产者生产数据不丢失1.2、broker中数据不丢失1.3、消费者消费数据不丢失2、Kafka配置文件说明 2.1、server.properties2.2、consumer.propertiesC++软件异常排查从入门到精通系列教程(核心精品专栏,订阅量已达600多个,欢迎订阅,持......
  • docker部署RocketMQ.240108
    ​RocketMQ是阿里巴巴2016年MQ中间件,使用java语言开发,在阿里内部,RocketMQ承接了例如“双11”等高并发场景的消息流转,能够处理亿万级别的消息处理。RocketMQ各角色介绍Producer:消息的发送者Consumer:消息的接收者Broker:暂存和传输消息,如:邮局NameServer:管理Bro......
  • 史上最强的Kafka可视化WebUI工具,涵盖多种功能
    KafkaWebUIByLCCgithub地址GitHub-lichengchuan/KafkaWebUIByLCC:KafkaWebUIByLCC是一个专为简化ApacheKafka集群管理和操作而设计的图形化用户界面(GUI)。该项目旨在为开发者、运维人员和数据科学家提供一个直观且易用的平台,以进行Kafka主题(Topic)管理、消息生产和......
  • 【Azure Event Hub】Kafka消息发送失败(Timeout Exception)
    问题描述使用AzureEventHub,客户端通过kafka发送消息到EventHub中,规律性的遇见TimeoutException"sendfail;nestedexceptionisorg.springframework.kafka.kafkaException:xxx" 问题解答Kafka客户端与EventHub服务端的连接(Connection)空闲事件过长,EventHub服务端......
  • RabbitMQ高级篇之发送者可靠性 发送者确认的代码实现
    文章目录一、配置文件中启用确认机制二、编写`returnCallback`和`confirmCallback`三、消息确认测试四、性能注意事项总结一、配置文件中启用确认机制在application.yml或application.properties文件中开启publishconfirm和publishreturn:publishcon......
  • RocketMQ原理简述(二)
    1.前言此文章是在儒猿课程中的学习笔记,感兴趣的想看原来的课程可以去咨询儒猿课堂这篇文章紧挨着上一篇博客来进行编写,有些不清楚的可以看下上一篇博客:RocketMQ相关原理简述-CSDN博客2.topic,messageQueue,broker  topic的创建的时候需要进行指定MessageQueue的数量,那么t......
  • 【kafka】Kafka-Kraft 集群模式
    1.概述左图为Kafka现有架构,元数据在zookeeper中,运行时动态选举controller,由controller进行Kafka集群管理。右图为kraft模式架构(实验性),不再依赖zookeeper集群,而是用三台controller节点代替zookeeper,元数据保存在controller中,由controller直接进行Kafk......
  • RabbitMQ学习三 管理后台
    参考地址:https://www.cnblogs.com/cplinux/p/17937314https://blog.csdn.net/biexiansheng/article/details/103122511?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-1-103122511-blog-128546674.235^v43^pc_blog_bottom_rel......
  • Python--pika (rabbitmq)
    connectionconnection=BlockingConnection(ConnectionParameters(host='xxx',port=xxx,credentials=PlainCredentials(username='xxx',password='xxx')))channelchannel=connection.channel()生......
  • .NET Core + Kafka 开发指南
    什么是KafkaApacheKafka是一个分布式流处理平台,由LinkedIn开发并开源,后来成为Apache软件基金会的顶级项目。Kafka主要用于构建实时数据管道和流式应用程序。Kafka架构从下面3张架构图中可以看出KafkaServer实际扮演的是Broker的角色,一个KafkaCluster由多个Broker组成,......