大家好,我是石臻臻,这是 「kafka专栏」 连载中的第「10」篇文章…
一图知全貌
/cluster
/cluster/id 持久数据节点
集群ID
当第一台Broker启动的时候, 发现
/cluster/id
不存在,那么它就会把自己的cluster.id
配置写入zk; 标记当前zk是属于集群哪个集群; 后面其他的Broker启动的时候会去获取该数据, 如果发现数据跟自己的配置不一致; 则抛出异常,加入的不是同一个集群;
数据示例:
{"version":"1","id":"0"}
/controller_epoch 持久数据节点
Controller选举次数;
/Controller 临时数据节点
当前Controller角色的BrokerId,数据示例:
{"version":1,"brokerid":0,"timestamp":"1624415590383"}
删除该节点立马触发重新选举
/log_dir_event_notification
zk的数据中有一个节点
/log_dir_event_notification/
,这是一个序列号持久节点
这个节点在kafka中承担的作用是: 当某个Broker上的LogDir出现异常时(比如磁盘损坏,文件读写失败,等等异常): 向zk中谢增一个子节点
/log_dir_event_notification/log_dir_event_序列号
;Controller监听到这个节点的变更之后,会向Brokers们发送LeaderAndIsrRequest
请求; 然后做一些副本脱机的善后操作
/isr_change_notification/log_dir_event_{序列号}
当Isr有变更的时候,会写入这个节点Controller监听变更
/admin
/admin/delete_topics 待删除Topic
/admin/delete_topics/{topicName} 持久节点,待删除Topic
存在此节点表示 当前Topic需要被删除
/admin/reassign_partitions 持久数据节点
如果有此节点,表示当前正在进行数据迁移,里面的数据就是正在迁移的配置
示例数据:
/brokers
/brokers/seqid
/brokers/seqid
: 全局序列号
里面没有数据,主要是用了节点的
dataVersion
信息来当全局序列号
在kafka中的作用: 自动生成BrokerId
主要是用来自动生成brokerId;
一个集群如果特别大,配置brokerId的时候不能重复,一个个设置比较累; 可以让Broker自动生成BrokerId
server.properties
配置
设置Brokerid能够自动生成
broker.id.generation.enable=true
设置BrokerId<0 (如果>=0则以此配置为准)
broker.id=-1
自动生成配置的起始值
reserved.broker.max.id=20000
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/422a3cde16774e70de81eaf895626b59.jpeg)
独家面经总结,超级精彩
本人面试腾讯,阿里,百度等企业总结下来的面试经历,都是真实的,分享给大家!
Java面试准备
准确的说这里又分为两部分:
- Java刷题
- 算法刷题
Java刷题:此份文档详细记录了千道面试题与详解;
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
o-1713561495025)]
[外链图片转存中…(img-GkJNVvzd-1713561495027)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!