互联网科技老男孩的成长之路Java架构技术进阶

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

2020-06-11  本文已影响0人  java菲菲

kafka的外在表现很像消息系统,允许发布和订阅消息流,但是它和传统的消息系统有很大的差异:

kafka不仅仅是个消息中间件,同时它是个流平台,这个平台上可以发布和订阅数据流(kafka的流,有一个单独的包stream的处理),并把它们保存起来,进行处理,这个就是kafka作者的设计理念。

不装了大神了,上面说的这些都是这位大牛的手写kafka笔记里的,看完之后万分膜拜,所以今天小编也想分享出来给大伙瞧瞧,话不多说,上目录(内容有点多,先来看下,大概了解一下),如果需要这份下载完整的手写“Kafka笔记”的也可以直接来找我,【点击这里】即可。

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

01 kafka入门

1.1 什么是kafka

1.2 kafka中的基本概念

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜 公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

02 为什么选择kafka

2.1 优点

2.2 常见场景

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

03 kafka的安装、管理和配置

3.1 安装

3.2 Broker配置

3.3 硬件配置对kafka性能的影响

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜 公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

04 kafka的集群

4.1 为何需要kafka集群

4.2 如何估算kafka集群中Broker的数量

4.3 Broker如何加入kafka集群

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

05 第一个kafka程序

5.1 创建我们的主题

5.2 生产者发送消息

5.3 消费者接受消息

5.4 演示示例

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

06 kafka的生产者

6.1 生产者发送消息的基本流程

6.2 使用kafka生产者

6.3 序列化

6.4 分区

6.4.1 自定义分区器

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

07 kafka的消费者

7.1 消费者的入门

7.2 消费者中的基础概念

7.3 消费者中的核心概念

7.4 kafka中的消费安全

7.5 消费者提交偏移量导致的问题

7.6 分区再均衡

7.7 优雅1退出

7.8 反序列化

7.9 独立消费者

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜 公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

08 深入理解kafka

8.1 集群的成员关系

8.2 什么是控制器

8.3 复制-kafka的核心

8.4 处理请求的内部机制

8.5 物理存储机制

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜 公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

09 可靠的数据传递

9.1 kafka提供的可靠性保证和架构上的权衡

9.2 复制

9.3 Broker配置对可靠性的影响

9.4 可靠系统里的生产者

9.5 可靠系统里的消费者

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

10 kafka和Spring的整合

10.1 与Spring集成

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

11 SpringBoot和kafka的整合

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

12 kafka实战之削峰填谷

13 数据管道和流式处理(了解即可)

13.1 数据管道基本概念

13.2 流式处理基本概念

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

上面都是在说大牛的手写“Kafka笔记”,下面来谈谈kafka面试

关于kafka面试这一块,前阵子有收集一份面试真题(从基础[17]-进阶[15]-高阶[12],总共44道题)

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

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

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

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

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

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

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

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

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

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

11.哪些情景下会造成消息漏消费?

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

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

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

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

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

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

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

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

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

4.简述Kafka的日志目录结构

5.Kafka中有哪些索引文件?

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

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

8.聊一聊你对Kafka的Log Retention的理解

9.聊一聊你对Kafka的Log Compaction的理解

10.聊一聊你对Kafka底层存储的理解

11.聊一聊Kafka的延时操作的原理

12聊一聊Kafka控制器的作用

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

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

15.Kafka中的幂等是怎么实现的?

1.Kafka中的事务是怎么实现的?

2.失效副本是指什么?有哪些应对措施?

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

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

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

6.Kafka中的延迟队列怎么实现

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

8.Kafka中怎么做消息审计?

9.Kafka中怎么做消息轨迹?

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

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

12.Kafka的哪些设计让它有如此高的性能?

答案在这里啦!!整理起来好多呀,有30页....

公司来了位阿里P8大神,看完他的手写“Kafka笔记”,万分膜拜

关于kafka,今天就撩骚到这儿啦,有关上面的大牛手写“Kafka笔记”(PDF)以及面试进阶(word)都可直接来小编这里领取,【点击这里】便可!

上一篇下一篇

猜你喜欢

热点阅读