当前位置: 首页 > news >正文

【Kafka】Kafka Broker工作流程、节点服役与退役、副本、文件存储、高效读写数据-08

【Kafka】Kafka Broker工作流程、节点服役与退役、副本、文件存储、高效读写数据

  • 1. Kafka Broker 工作流程
    • 1.1 Zookeeper 存储的 Kafka 信息
    • 1.2 Kafka Broker总体工作流程
      • 1.2.1 Controller介绍
    • 1.3 Broker 重要参数
  • 2. 节点服役与退役
  • 3. Kafka副本

在这里插入图片描述

1. Kafka Broker 工作流程

1.1 Zookeeper 存储的 Kafka 信息

  1. 启动Zookeeper客户端
[atguigu@hadoop102 zookeeper-3.5.7]$ bin/zkCli.sh
  1. 通过 ls 命令可以查看 kafka 相关信息
[zk: localhost:2181(CONNECTED) 2] ls /kafka

在这里插入图片描述

在这里插入图片描述

1.2 Kafka Broker总体工作流程

在这里插入图片描述

  1. Broker注册:每个Kafka Broker在启动时会向ZooKeeper注册自己,ZooKeeper维护一个活动Broker列表,这个列表便于集群中的各个Broker相互发现并进行通信。

  2. Leader选举: Controller负责选举分区的领导者。当一个分区的领导者副本不可用时,Controller会选择一个新的副本作为领导者。选举结果通过ZooKeeper更新,并通知所有相关的Broker。

  3. 监控: Controller会监控Broker节点的变化。

  4. Controller决定选举:选举规则:在isr中存活为前提,按照AR中排在前面的优先。例如ar[1,0,2], isr [1,0,2],那么leader就会按照1,0,2的顺序轮询

  5. Controller将节点信息上传到ZK

  6. Controller将领导者选举的结果和副本状态变更通知所有相关的Broker,确保它们有最新的元数据信息。

1.2.1 Controller介绍

在Kafka集群中,并不是每个Broker都有一个Controller,而是整个集群中只有一个活跃的Controller。这个Controller由一个Broker担任,其职责是管理和协调整个集群的元数据和状态变更。以下是关于Kafka Controller的详细介绍:

Kafka Controller职责

  1. 分区副本状态管理:
    领导者选举: 当一个分区的领导者副本不可用时,Controller负责选举新的领导者副本,确保分区始终有一个活跃的领导者来处理读写请求。
    副本同步: Controller监控副本的状态,并确保追随者副本与领导者副本保持同步。不同步的副本会被标记为“Out of Sync”(OOS)。
  2. Broker管理:
    Broker注册和注销: 当一个Broker加入或退出集群时,Controller会更新集群的元数据,并重新分配分区和副本,以确保负载均衡和高可用性。
    集群扩展和缩减: Controller处理Broker的增加或减少,进行相应的分区和副本重新分配。
  3. 分区重新分配:
    负载均衡: 当集群中负载不均衡时,Controller可以根据配置重新分配分区和副本,确保各个Broker的负载均衡。
    分区迁移: Controller协调分区和副本在不同Broker之间的迁移,实现高效的负载管理和故障恢复。
  4. 集群元数据管理:
    元数据更新: Controller管理集群范围内的所有元数据更新,包括主题创建、删除、配置变更等。
    通知Broker: 当元数据发生变化时,Controller通知所有相关的Broker,确保它们使用最新的配置信息。
  5. 故障检测和恢复:
    Broker故障检测: Controller定期检查Broker的状态,如果检测到某个Broker故障,它会触发相应的故障恢复机制。
    故障恢复: 在Broker故障的情况下,Controller重新分配该Broker上的分区和副本,确保消息的高可用性和数据的完整性。

Controller与Broker的关系

  • 控制器是一个特殊的Broker:虽然Controller执行管理和协调任务,但它本质上还是一个Broker,也处理正常的消息生产和消费请求。
  • 单一Controller:在任何时候,Kafka集群中只能有一个活跃的Controller。其他Broker在需要时可以通过选举成为Controller。

1.3 Broker 重要参数

在这里插入图片描述
在这里插入图片描述

2. 节点服役与退役

3. Kafka副本

// P31 TODO

http://www.lryc.cn/news/378978.html

相关文章:

  • 如何恢复未格式化分区数据?看这里!
  • 通过“BOSS”精通比特币,深入认识私钥、账户和钱包
  • 进程与线程的区别
  • 【AI基础】第五步:纯天然保姆喂饭级-安装并运行chatglm3-6b
  • 【学习笔记】Elastic-Job和Quartz 实现企业级定时任务
  • 舒适佩戴,享受沉浸式音乐体验,西圣AVA2耳机体验
  • c++学习-----内存管理
  • 可视化数据科学平台在信贷领域应用系列七:自动机器学习(下篇)
  • OpenGL Super Bible 7th-Primitives, Pipelines, and Pixels图元、渲染管线与像素
  • SpringBoot3.0更新后,IDEA创建SpringBoot2.x项目
  • Linux开发讲课8--- linux的5种IO模型
  • 什么是云主机?
  • 力扣上的经典问题:接雨水
  • 双例集合(二)——双例集合的实现类之HashMap容器类
  • oracle-定时器(job)
  • cron.timezone
  • Hadoop+Spark大数据技术(测试)
  • 使用新语法连接Qt 5中重载的信号和槽
  • 梯度提升决策树(GBDT)的训练过程
  • 路由器的Wi-Fi性能是否限制了你的网速?这里有你想要的答案
  • 简站WordPress是最简洁好用易上手的wordpress企业建站主题
  • 阿里云 debian10.3 sudo apt-get updat 报错的解决方案
  • vite中使用scss技巧
  • PyQt5/Pyside2学习记录
  • 记一次通过脚本来实现自定义容器的自动重启
  • 基于Django、Bootstrap的电影推荐系统,算法基于用户的协同过滤算法,有爬虫有可视化后台
  • mysql、mariadb 登录主机的含义,如何修改登录主机,如何删除登录主机
  • c++ 设计模式 的课本范例
  • QT中绘制点阵
  • 机器人里程计(Odometry)