【知识体系】Kafka文档汇总、组成及架构,配置,常见名词解释,命令行及api操作,官方文档内容,各部分深入,zookeeper和security,监控和运维
〇、相关资料
1、快速搭建文档:
2、详细讲义
3、在线官方文档:http://kafka.apache.org/documentation/
4、Kafka知识个人总结
5、KafkaPPT汇报
链接:https://pan.baidu.com/s/16VufOVYu8H1I13sENnvN1A
提取码:USTC (1,2,4,5)
一、基本介绍
1、概念
- 分布式的、基于发布/订阅模式的数据流式传输平台
消息队列的5种工作模式:https://www.cnblogs.com/misscai/p/9989276.html
- 特点:流式数据、集群方式运行、容错方式存储、消息及时处理、通过保留期限参数持久化保存发布的记录、副本机制
- 消息记录的组成:键、值、时间戳
2、架构

3、项目目录

4、配置文件详解
server.properties https://www.cnblogs.com/alan319/p/8651434.html
生产者与消费者 https://blog.csdn.net/universsky2015/article/details/115234772
二、概念/参数/特性详解
1、常见名词解释
- 基本组成
- Broker
- Topic
- Partition:一个partition只能被一个consumer消费
- Leader
- Follower
- Producer
- Consumer
- Offset
- log
- Consumer Group:对同一个topic的多个consumer,GC内的多个consumer会进行负载均衡【消息可能会发送到一个组(单播)或多个组(广播)】
- Quotas:配额,控制客户端使用的代理资源,避免流量超过阈值从而降低用户体验,会根据user和client进行设置
- 使用kafka-configs.sh命令行进行设置
- 认证方式
- PLAINTEXT:明文/纯文本,在broker客户端配置kafka_server_jaas.conf认证信息,是无安全认证的监听方式
- SSL:Secure Sockets Layer,安全套接字协议(密文)
- SASL:Simple Authentication and Security Layer,简单认证和安全层,SASL_PLAINTEXT/SASL_SSL是有安全认证的监听方式,SASL可以使用PLAIN和SCRAM机制
- PLAIN:明文,只需要在JAAS中配置server和client的认证信息
- JAAS:Java Authentication and Authorization Service,Java认证和授权服务,需要在客户端中配置kafka_client_jaas.conf文件,配置明文认证信息KafkaClient
- SCRAM:Salted Challenge Response Authentication Mechanism,盐化的质询响应认证机制,可以不用重启就能新增用户,与PLAIN是两种常用的权限认证方式
- 只能使用安全传输层协议TLS,Transport Layer Security,配置JAAS文件的同时使用命令行设置认证方式
- 通过 SCRAM-SHA-256【Strong Hash,强密码和强迭代技术】和SCRAM-SHA-512两种安全认证方式配合TLS完成安全权限认证
- PLAIN:明文,只需要在JAAS中配置server和client的认证信息
- ACL:用户权限控制/访问控制列表,一种权限认证方式
- 需要配置allow.everyone.if.no.acl.found=true【如果无ACL权限控制,就允许任意用户进行访问】
- 通过kafka-acls.sh对用户/主机/principal主体设置读写等权限
- Multi-tenancy:多租户模式,可以实现用户空间、集群共享,权限认证
- 关系:SASL(_PLAINTEXT)安全认证,需要先配置broker和client的JAAS文件,可以使用PLAIN(只需要配置jaas即可)/SCRAM(包含两种安全认证/加密方式,配置jaas+命令行添加配置)进行加密【jaas+命令行】
三、使用
1、命令行操作(见文档)
- 安装与配置
- 启动停止
- topic的CRUD
- 消息的生产消费
2、Kafka Client API操作

3、Producer API
- 异步发送包括两个线程:main线程和sender线程

- main将消息发送到RecordAccumulator,sender从RecordAccumulator拉取到broker
- 包含带回调函数的api和不带回调函数的api
- producer收到ack时调用,ProducerRecord构造中多一个参数--Callback的匿名内部类的onCompletion方法
- 同步发送API
- 发送消息后阻塞进程,直至返回ack
- 方式:producer.send()后加.get()
4、Consumer API
- Kafka数据持久化,不会丢失
- 消费者需要考虑对offset的维护
- 自动提交offset:参数--enable、interval.ms时间间隔
- 缺陷:基于时间,无法把握时机
- 手动提交offset
- 分为commitSync(同步提交)和commitAsync(异步提交)
- 同步提交阻塞进程直至成功,自动失败重试,可靠,但吞吐量受影响
- 异步提交无失败重试。
- 两种方式均可能导致数据漏消费(先提交后消费)或重复消费(先消费后提交)
- 自动提交offset:参数--enable、interval.ms时间间隔
5、自定义Interceptor拦截器
- 对client的定制化逻辑控制
- 在消息发送前或producer回调逻辑前对消息做定制化需求
- 可以指定多个Interceptor形成拦截器链
- 实现接口是ProducerInterceptor,包括configure、onSend(可以对消息进行操作)、onAcknowledgement(成功或失败时调用)、close方法
- 配置对象prop.put(interceptorsList)
6、官方文档内容


- 快速入门
- 常用API(需要导入的maven包)
- 配置(不同属性描述)
- 设计(ISR、log、Partition的副本Replica机制、配额Quota)
- 实施(消息记录格式头、集群结构)
- 常见操作(多租户)
- 安全(SSL/SASL/授权/ACL)
- Kafka连接(Java连接函数)
- Kafka流
五、深入介绍
1、工作流程
- topic即目录,partition是物理概念,与log一一对应
- log存储生产的数据,数据会追加到log/partition末尾,通过offset记录索引
- consumer会实时记录offset,便于出错时恢复并继续消费
2、文件存储【分片和索引机制】
- 防止log过大,将其拆分为多个segment
- 每个segment包括.log和.index文件,均以当前segment第一条消息的偏移量命名
- 方便old segment的删除,提高磁盘利用率,生命周期由服务器端参数配置

- .log存消息内容,.index存放索引(二分查找到指定消息)及物理偏移量/元数据的内存地址(快速定位消息)

3、生产者
- 数据会被封装为ProducerRecord对象
- 保证可靠性:partition向生产者发送ack
- 分区(得到生产者向第几个partition发送消息,是ProducerRecord构造的参数):便于扩展,提高并发
- 分区策略:指明、key的hash与partition数取余、round-robin算法(随机数与partition数取余)等
- 出故障后会从ISR中选取leader
- acks应答机制,参数(0,1,-1):对leader和followers约束是否落盘,提高可靠性
- LEO:每个副本的最后一个offset
- HW:所有ISR副本中最小的LEO
- 重要消息的幂等机制:exactly once语义保证消息只被发送一次
副本同步策略:leader维护ISR,副本未同步(根据副本数量,发送ack)会被踢出
故障处理:通过对follower使用LEO和HW方法,选举产生leader,解决生产者和消费者故障
4、消费者
- 消费方式:pull模式,根据消费能力从broker获取消息,并通过timeout参数避免长时间获取空参数
- 分区分配策略:确定partition由哪个CG消费
- RoundRobin(基于topic级别轮询消费)
- Range(基于整体partition均分消费)
- 分区再平衡:reblance
- CG新增消费者,消费者离开CG,topic新增partition
- 用于offset维护的topic,避免consumer宕机:zookeeper维护 → 内部topic:__consumer_offsets
- GC:同一GC内的多个消费者,在同一时刻只能有一个消费者在读取数据
5、高效读写的实现
- 写:往硬盘中追加写而不随机写(先写到cache,再同步写入硬盘)
- 读:Linux和Unix的零拷贝机制(直接将数据发送到网卡,而无需拷贝到Kafka服务中)
- 往磁盘中循环读写,保证数据不会丢失

6、zookeeper的作用
- 对broker和Consumer的元数据进行管理
- 选举并管理Controller
- Controller负责:管理集群中的其他broker上下线,以及分区副本分配和leader选举等


7、监控运维
- Kafka Manager:IP ADDR:30990
- Kafka Monitor
- ZK Web UI:IP ADDR:8098
8、其他问题
- config中的Bootstrap-server:源码内部使用的实际上就是broker-list,但并未使用Kafka的服务,而是使用了外部服务Bootstrap-server
六、Security
1、安全认证方式


【知识体系】Kafka文档汇总、组成及架构,配置,常见名词解释,命令行及api操作,官方文档内容,各部分深入,zookeeper和security,监控和运维的更多相关文章
- 一图解释PHPstorm代码片段设置---附官方文档(转)
参考:https://blog.csdn.net/thinkthewill/article/details/81145106 资料 设置片段[官方设置教程] 设置变量对话框[官方设置教程] phpst ...
- Django QuestSet API (官方文档)
1.返回新查询集的方法 (1)filter():滤指定条件的结果 Entry.objects.filter(pub_date__gt=datetime.date(2005, 1, 3), headli ...
- 常用SQL_官方文档使用
SQL语句基础理论 SQL是操作和检索关系型数据库的标准语言,标准SQL语句可用于操作关系型数据库. 5大主要类型: ①DQL(Data Query Language,数据查询语言)语句,主要由于se ...
- 入门常用SQL及官方文档的使用
SQL语句基础理论 SQL是操作和检索关系型数据库的标准语言,标准SQL语句可用于操作关系型数据库. 5大主要类型: ①DQL(Data Query Language,数据查询语言)语句,主要由于se ...
- Spring 4 官方文档学习(十一)Web MVC 框架
介绍Spring Web MVC 框架 Spring Web MVC的特性 其他MVC实现的可插拔性 DispatcherServlet 在WebApplicationContext中的特殊的bean ...
- 【一个iOS官方文档错误】关于keyWindow是否可以接受触摸事件?
[一个iOS文档错误]关于keyWindow是否可以接受触摸事件? 关于keyWindow,官方文档有一个解释: 同一时间只有一个window可以成为keyWindow,keyWindow可以接受 ...
- [Python3]Python官方文档-Python Manuals
简介 一般情况下,初学者都不愿意直接去浏览Python Manuals,即Python自带的官方文档.尤其是只有英文版的情况下,初学者更加不会去使用该官方文档了. 在这里笔者强力推荐初学者经常学会使用 ...
- Mysql优化(出自官方文档) - 第九篇(优化数据库结构篇)
目录 Mysql优化(出自官方文档) - 第九篇(优化数据库结构篇) 1 Optimizing Data Size 2 Optimizing MySQL Data Types 3 Optimizing ...
- [Redis知识体系] 一文全面总结Redis知识体系
本系列主要对Redis知识体系进行详解.@pdai Redis教程 - Redis知识体系详解 知识体系 学习资料 知识体系 知识体系 相关文章 首先,我们通过学习Redis的概念基础,了解它适用的场 ...
- 《KAFKA官方文档》入门指南(转)
1.入门指南 1.1简介 Apache的Kafka™是一个分布式流平台(a distributed streaming platform).这到底意味着什么? 我们认为,一个流处理平台应该具有三个关键 ...
随机推荐
- 使用Jumpserver堡垒机管理MySQL应用
第一步,添加系统用户 资产管理,系统用户,创建<数据库协议>MySQL 用户名和密码填写实际可以访问数据库的用户名和密码 第二步,添加应用 应用管理,数据库 主机和端口填写可以访问数据库的 ...
- ConfigMap使用说明
ConfigMap概述 ConfigMap供容器使用的典型用法如下. (1)生成为容器内的环境变量. (2)设置容器启动命令的启动参数(需设置为环境变量). (3)以Volume的形式挂载为容器内部的 ...
- 2>&1到底是什么意思?
java -jar snapshot.jar > snapshot.log 2>&1 & 写Java的朋友一定对上面的命令很熟悉,相信大部分人都知道>表示的是重定向, ...
- python运行以及入门语法基础
pycharm下载与使用 1.pycharm官网下载(直接到pycharm下载地址) http://www.jetbrains.com/pycharm/download/#section=window ...
- 「Tubian」Tubian0.41!支持Windows QQ微信!
Tubian 0.42已发布:https://www.cnblogs.com/tubentubentu/p/16745926.html Sourceforge.net下载:https://source ...
- .NET 开源项目推荐之 直播控制台解决方案 Macro Deck
流媒体是一个吸引数亿万玩家的严肃行业. 最受欢迎的游戏锦标赛的转播获得了数百万的观看次数,从商业角度来看,这也使游戏行业变得有趣.在直播圈有个很受欢迎的直播控制台程序Macro Deck, 它是基于A ...
- 撸了一个简易的配置中心,顺带整合到了SpringCloud
大家好,我是三友~~ 最近突然心血来潮(就是闲的)就想着撸一个简单的配置中心,顺便也照葫芦画瓢给整合到SpringCloud. 本文大纲 配置中心的概述 随着历史的车轮不断的前进,技术不断的进步,单体 ...
- HNOI2008GT考试
题目链接 考虑dp,f(i,j)表示做到了第i位(共n位),当前的后缀串与A1~Aj相匹配 接下来的方案数.转移的话枚举一个k=0~9表示这位选什么,如果选了以后,匹配的位置会改变到 j' ,j'可以 ...
- 【做题笔记】CSP-S 往年试题
题单 本文章正在持续更新-- [2021] 廊桥分配 题目 题面描述 所有飞机分为两类--国内区和国际区,两区廊桥数量互不干扰.每架飞机遵循"先到先得"的原则,优先选择编号最小的廊 ...
- 前端框架Vue------>第一天学习(3)
文章目录 8 .使用Axios实现异步通信 9 .表单输入绑定 9.1 . 什么是双向数据绑定 9.2 .为什么要实现数据的双向绑定 9.3 .在表单中使用双向数据绑定 8 .使用Axios实现异步通 ...