Kafka - Kafka Broker
一、Kafka Broker 工作流程
1.1 ZooKeeper中存储的kafka信息
补充说明下/kafka/controller, 每个broker模块都将有一个controller模块,在竞争leader时谁先抢到/kafka/controller节点,谁来节点谁是leader。因此说/kafka/controller节点只是辅助作用。
1.2 Kafka Broker总体工作流程
二、Kafka Broker 节点服役和退役
2.1 服役新节点
新节点准备
执行均衡分区(数据转移)操作
1)创建需要数据转移的topic
vim topics-to-move.json { "topics": [ {"topic": "first"} ], "version": 1 }
2) 生成一个负载均衡的计划 :
- bin/kafka-reassign-partitions.sh 执行均衡分区的脚本;
- --topics-to-move-json-file topics-to-move.json 需要均衡的topic是上一步创建的
- -broker-list "0,1,2,3" 参与均衡分区的broker有
- --generate代表生成计划,并未执行
bin/kafka-reassign-partitions.sh --bootstrap-server hadoop102:9092 --topics-to-move-json-file topics-to-move.json --broker-list "0,1,2,3" --generate
返回结果
//未修改前的分区负载情况 Current partition replica assignment {"version":1,"partitions":[{"topic":"first","partition":0,"replic as":[0,2,1],"log_dirs":["any","any","any"]},{"topic":"first","par tition":1,"replicas":[2,1,0],"log_dirs":["any","any","any"]},{"to pic":"first","partition":2,"replicas":[1,0,2],"log_dirs":["any"," any","any"]}]} //计划修改为如下分区负载情况 Proposed partition reassignment configuration {"version":1,"partitions":[{"topic":"first","partition":0,"replic as":[2,3,0],"log_dirs":["any","any","any"]},{"topic":"first","par tition":1,"replicas":[3,0,1],"log_dirs":["any","any","any"]},{"to pic":"first","partition":2,"replicas":[0,1,2],"log_dirs":["any"," any","any"]}]}
3) 创建副本存储计划(把上一步 “计划修改为如下分区负载情况” 拷贝下来)
vim increase-replication-factor.json
{ "version":1, "partitions":[ {"topic":"first", "partition":0, "replicas":[2,3,0], "log_dirs":["any","any","any"] }, {"topic":"first", "partition":1, "replicas":[3,0,1], "log_dirs":["any","any","any"] }, {"topic":"first", "partition":2, "replicas":[0,1,2], "log_dirs":["any","any","any"] }] }
4) 执行副本存储计划:
bin/kafka-reassign-partitions.sh --bootstrap-server hadoop102:9092 --reassignment-json-file increase-replication-factor.json --execute
5)验证副本存储计划
bin/kafka-reassign-partitions.sh --bootstrap-server hadoop102:9092 --reassignment-json-file increase-replication-factor.json --verify
返回结果
Status of partition reassignment: Reassignment of partition first-0 is complete. Reassignment of partition first-1 is complete. Reassignment of partition first-2 is complete. Clearing broker-level throttles on brokers 0,1,2,3 Clearing topic-level throttles on topic first
2.2 退役旧节点
和2.1节类似,只是创建执行计划时,改为 --broker-list "0,1,2" 即可。
具体参考:https://achang.blog.csdn.net/article/details/123054073
分类:
Kafka
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?