Kafka面试题全套整理 | 划重点要考!

做积极的人,而不是积极废人!

有很多人问过我要过Kafka相关的面试题,我一直懒得整理,这几天花了点时间,结合之前面试被问过的、别人咨询过的、我会问别人的进行了相关的整理,也就几十题,大家花个几分钟看看应该都会。面试题列表如下:

  • Kafka的用途有哪些?使用场景如何?

  • Kafka中的ISR、AR又代表什么?ISR的伸缩又指什么

  • Kafka中的HW、LEO、LSO、LW等分别代表什么?

  • Kafka中是怎么体现消息顺序性的?

  • Kafka中的分区器、序列化器、拦截器是否了解?它们之间的处理顺序是什么?

  • Kafka生产者客户端的整体结构是什么样子的?

  • Kafka生产者客户端中使用了几个线程来处理?分别是什么?

  • Kafka的旧版Scala的消费者客户端的设计有什么缺陷?

  • “消费组中的消费者个数如果超过topic的分区,那么就会有消费者消费不到数据”这句话是否正确?如果不正确,那么有没有什么hack的手段?

  • 消费者提交消费位移时提交的是当前消费到的最新消息的offset还是offset+1?

  • 有哪些情形会造成重复消费?

  • 那些情景下会造成消息漏消费?

  • KafkaConsumer是非线程安全的,那么怎么样实现多线程消费?

  • 简述消费者与消费组之间的关系

  • 当你使用kafka-topics.sh创建(删除)了一个topic之后,Kafka背后会执行什么逻辑?

  • topic的分区数可不可以增加?如果可以怎么增加?如果不可以,那又是为什么?

  • topic的分区数可不可以减少?如果可以怎么减少?如果不可以,那又是为什么?

  • 创建topic时如何选择合适的分区数?

  • Kafka目前有那些内部topic,它们都有什么特征?各自的作用又是什么?

  • 优先副本是什么?它有什么特殊的作用?

  • Kafka有哪几处地方有分区分配的概念?简述大致的过程及原理

  • 简述Kafka的日志目录结构

  • Kafka中有那些索引文件?

  • 如果我指定了一个offset,Kafka怎么查找到对应的消息?

  • 如果我指定了一个timestamp,Kafka怎么查找到对应的消息?

  • 聊一聊你对Kafka的Log Retention的理解

  • 聊一聊你对Kafka的Log Compaction的理解

  • 聊一聊你对Kafka底层存储的理解(页缓存、内核层、块层、设备层)

  • 聊一聊Kafka的延时操作的原理

  • 聊一聊Kafka控制器的作用

  • 消费再均衡的原理是什么?(提示:消费者协调器和消费组协调器)

  • Kafka中的幂等是怎么实现的

  • Kafka中的事务是怎么实现的(这题我去面试6家被问4次,照着答案念也要念十几分钟,面试官简直凑不要脸。实在记不住的话...只要简历上不写精通Kafka一般不会问到,我简历上写的是“熟悉Kafka,了解RabbitMQ....”)

  • Kafka中有那些地方需要选举?这些地方的选举策略又有哪些?

  • 失效副本是指什么?有那些应对措施?

  • 多副本下,各个副本中的HW和LEO的演变过程

  • 为什么Kafka不支持读写分离?

  • Kafka在可靠性方面做了哪些改进?(HW, LeaderEpoch)

  • Kafka中怎么实现死信队列和重试队列?

  • Kafka中的延迟队列怎么实现(这题被问的比事务那题还要多!!!听说你会Kafka,那你说说延迟队列怎么实现?)

  • Kafka中怎么做消息审计?

  • Kafka中怎么做消息轨迹?

  • Kafka中有那些配置参数比较有意思?聊一聊你的看法

  • Kafka中有那些命名比较有意思?聊一聊你的看法

  • Kafka有哪些指标需要着重关注?

  • 怎么计算Lag?(注意read_uncommitted和read_committed状态下的不同)

  • Kafka的那些设计让它有如此高的性能?

  • Kafka有什么优缺点?

  • 还用过什么同质类的其它产品,与Kafka相比有什么优缺点?

  • 为什么选择Kafka?

  • 在使用Kafka的过程中遇到过什么困难?怎么解决的?

  • 怎么样才能确保Kafka极大程度上的可靠性?

  • 聊一聊你对Kafka生态的理解

如果上面的问题都能掌握,相信在面试Kafka的时候肯定能够完全应付。如果还应付不了,请告知公司及职位,我去投简历会会他。如果上面1/3题回答都有难度的话,是该好好学习一下Kafka啦。

建议收藏本文,准备找工作前可以对着复习一下。

不要问面试题答案在哪里,书上都有写哦~

《深入理解Kafka》随书代码下载

购买入口(半价中)

【End】

推荐阅读:

Java 最常见的 200+ 面试题

关注下方二维码,订阅更多精彩内容。

转发朋友圈,是对我最大的支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/546717.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于Java基础你不得不会的34个问题

目录1. 面向对象和面向过程的区别2. Java 语言有哪些特点3. 关于 JVM JDK 和 JRE 最详细通俗的解答4. Oracle JDK 和 OpenJDK 的对比5. Java和C的区别6. 什么是 Java 程序的主类 应用程序和小程序的主类有何不同7. Java 应用程序与小程序之间有那些差别8. 字符型常量和字符串常…

Android--快速接入微信支付

前言 最近实习的时候要求我做支付模块,主要是介入支付宝支付和微信支付的。支付宝支付接入相对来说比较好做,官网文档也比较容易懂。但是做微信支付的时候,官网文档就有点懵逼了,不过慢慢读还是能够开通的。与是抽时间记录一下微…

PyQt5 QTreeWidget更改item项前的展开折叠三角图标

把下面代码放到对话框初始化函数中即可 # 设置树控件样式self.treeWidget.setStyleSheet("QTreeView::branch:open:has-children:!has-siblings,""QTreeView::branch:open:has-children:has-siblings {image: url(:/pic/images/minus.png);}""QTreeVi…

聊一聊开发常用小工具

作者:肥朝 来自:肥朝(ID:feichao_java)之前不少朋友问到平时怎么学习的.今天就简单介绍一下平时用到的一些小工具.首先我平时是用IDEA开发的,所以下面的介绍都是和IDEA相关的.本文主要介绍我平时在哪些场景使用,使用了…

YOLOv5的详细使用教程,以及使用yolov5训练自己的数据集

YOLOv5的详细使用教程,以及使用yolov5训练自己的数据集 文章目录: 1 安装环境依赖 1.1 克隆项目1.2 安装必要的环境依赖2 下载预训练模型和标注的数据集 2.1 下载预训练模型 2.1.1 执行脚本下载预训练模型2.1.2 直接下载预训练模型,然后保存…

六、PyQt5 QTreeWidget操作,获取树控件所有2级目录内容

新建pyqt5工程目录,添加树控件QTreeWidget,添加4个按钮,分别是添加 、删除、修改、打印树内容按钮,并添加按钮单击消息响应函数。 适用于QTreeWidget树控件只有2级目录内容情况 将树控件一级目录作为键,二级目录作为其对应键值存储到字典中。 # 树控件的字典,例如:dict…

多线程小抄集

Java中线程的状态 NEW、RUNNABLE(RUNNING or READY)、BLOCKED、WAITING、TIME_WAITING、TERMINATEDJava将操作系统中的运行和就绪两个状态合并称为运行状态。阻塞状态是线程阻塞在进入synchronized关键字修饰的方法或代码块(获取锁&#xff0…

使用rancher-2.5.5部署单节点kubernetes集群

rancher2.5.x发布,除了新的feature外,更加简洁,体验/研究/熟悉一下,方便后续的落地使用。感觉:太爽了 相关版本信息: rancher:v2.5.5 helm3:v3.5.1 kubernetes:1.19.…

1-2.Win10系统利用Pycharm社区版安装Django搭建一个简单Python Web项目的步骤之二

七、在项目下新建 templates 路径 在工程上,右键,添加templates目录 注意*: 此目录下即用来存放我们的html文件; 此目录一般是与app的主目录是平级的。当然也可以建立在app的目录下,主要取决于你的模板,一般是全局…

k8s-自动横向伸缩pod 根据CPU使用率,QPS访问数监控指标

k8s-自动横向伸缩pod 与节点 简述 我们可以通过调高ReplicationController、 ReplicaSet、 Deployment等可伸缩资源的rep让cas字段, 来手动实现pod中应用的横向扩容。 我们也可以通过增加pod容器的资源请求和限制来纵向扩容pod (尽管目前该操作只能在pod创建时&am…

记一次蚂蚁金服的面试经历

2015在实习的时候,当时一个一起实习的朋友在2019年3月份的时候突然在微信上找我,问我要不要面试下蚂蚁金服。问了下相关信息才知道他在2018年11月的时候进到蚂蚁金服,现在招人就想到了我,问我要不要试一下。刚开始还是有所顾虑的&…

记一次阿里巴巴一面的经历

上周在拉勾上收到一个蚂蚁金服的大哥要我的简历,当时很惊讶,居然有蚂蚁金服的找到我,然后想都没想就给了。受宠若惊呀,我知道自己的水平跟阿里的差距有多远,以前一直没用勇气去投,连试试都不敢。这次居然主…

Can‘t find a suitable configuration file in this directory or any parent. 报错解决错误

docker-compose 执行的时候报错 Cant find a suitable configuration file in this directory or any parent. Are you in the right directory? 解决办法: 1.把文件名重命名为docker-compose.yml,然后进入docker-compose.yml所在目录 2.然后在执行 docker…

Python获取两个列表list的不同之处

python Pycharm开发平台,列表listA包含listB,现在需要取出两个list中的不同值,diff_list[“23”, “78”] 说明: 转换为set再相减的目的去除list中重复的元素; # -*- coding: utf-8 -*-listA ["23", &quo…

jquery选择器《-》

2019独角兽企业重金招聘Python工程师标准>>> 1.DOM筛选,遍历查找相关方法 2.选择器中特殊符号的处理 3.改写原生js例子 a.表格隔行变色 b.tab标签页4.选择器的优化准则(初级)筛选 eq()选择指定索引的元素 filter(表达式)筛选指定表达式的元素first…

一文带你轻松搞懂事务隔离级别(图文详解)

本文由 SnailClimb 和读者 BugSpeak 共同完成。事务隔离级别(图文详解)什么是事务?事务是逻辑上的一组操作,要么都执行,要么都不执行。事务最经典也经常被拿出来说例子就是转账了。假如小明要给小红转账1000元,这个转账会涉及到两个关键操作…

Yolo opencv刻度尺识别 刻度读数识别 水尺识别 水位识别源码

刻度识别项目 简介实现效果实现流程实现原理 刻度尺的标定 指针位置标定读数位置标定刻度线标定数字检测数字分割数字识别web部署附录简介 好久不见了,我看了一下我最近的博客到现在已经3个月时间没更新了。这是因为我最近都在忙毕业设计,所以一直没有时…

Python检查特定值是否包含在列表中

python 检查特定值是否包含在列表中 # -*- coding: utf-8 -*-listA ["23", "45", "78", "92"] strB "45" strC "12"if __name__ __main__:if strB in listA:print(%s is on the list % strB)if strC not in …

【数据结构与算法】通俗易懂说链表

一:概述链表(Linked list)由一些节点组成,物理存储非连续的线性表。其中每个节点都会存储下个节点的指针,由于实际存储空间不连续,对链表插入节点,删除节点可以达到O(1)的复杂度,但是…

Yolov5实现道路裂缝检测

Yolov5实现道路裂缝检测 GitHub参考代码链接 我修改后的代码百度网盘链接 密码:2mzl 数据集链接 密码:06dj 基于Pytorch的Yolov5道路裂缝检测程序运行说明。大家可以结合我的说明和原文说明使用,有问题欢迎询问。 文章目录 Yolov5实现…