日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

大数据-kafka学习(三)——Kafka Broker

發布時間:2024/1/18 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 大数据-kafka学习(三)——Kafka Broker 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目錄

一、Kafka Broker工作

1.1 、zookeeper中存儲的kafka信息

1.2、broker總體工作流程

二、kafka副本

2.1、副本的基本信息

2.2、Leader選舉流程

2.3、Leader 和 Follower 故障處理細節

1、Leader故障處理

2、Follower故障處理

一、Kafka Broker工作

1.1 、zookeeper中存儲的kafka信息

在zookeeper的服務器端存儲的Kafka相關信息:

  • /brokers/ids [0,1,2] 記錄有哪些服務器
  • /brokers/topics/first/partitions/0/state? ? {"leader":1,"isr":[1,0,2]} 記錄誰是Leader,有哪些服務器可用
  • /controller? {"brokerid":0}? 輔助選舉Leader

1.2、broker總體工作流程

二、kafka副本

2.1、副本的基本信息

  • Kafka副本作用:提高數據可靠性
  • Kafka默認副本1個,生產環境一般配置為2個,保證數據可靠性;太多副本會增加磁盤存儲空間,增加網絡上的傳輸,降低效率。
  • Kafka中副本分為:Leader 和 Follower。Kafka生產者只會把數據發往Leader,然后Follower找Leader進行同步數據
  • Kafka分區中的所有副本統稱為AR(Assigned Repllicas)
  • ? ? ? ? AR = ISR + OSR

    ? ? ? ? ISR:表示和Leader保持同步的Follower集合,如果Follower長時間未向Leader發送通信請求或者同步數據,則該Follower將被踢出ISR。該時間閾值由replica.lag.time.max.ms參數設定,,默認30s。Leader發生故障之后,就會從ISR中選舉新的Leader。

    ? ? ? ? OSR:表示Follower與Leader副本同步時,延遲過多的副本。? ? ? ? ? ? ? ? ?

    2.2、Leader選舉流程

    ? ? ? ? Kafka集群中有一個broker的Cntroller會被選舉為Controller Leader,負責管理集群broker的上下線,所有topic的分區副本分配和Leader選舉等工作。

    ? ? ? ? Controller的信息同步工作是依賴于Zookeeper的。

    ?選舉規則:在ISR中存活為前提,按照AR中排在前面的優先。
    ????????例如:AR【1,0,2】、ISR【1,0,2】,那么Leader就會按照【1,0,2】進行輪詢產生?

    2.3、Leader 和 Follower 故障處理細節

    LEO(Log End Offset): 每個副本等最后一個offset,LEO其實就是最新的offset+1

    HW(High Watermark)?:所有副本中最小的LEO

    1、Leader故障處理

  • ?Leader發生故障之后,會從ISR中選出一個新的Leader
  • 為保證多個副本之間的數據一致性,其余的Follower會先將各自的log文件高于HW的部分截掉,然后從新的Leader同步數據。
  • ? ? ? ? 注意:這只能保證副本之間的數據一致性,并不能保證數據不丟失或者不充分

    2、Follower故障處理

    ? ? ? ?

  • ?Follower發生故障后被臨時踢出ISR
  • 這個期間Leader 和Follower繼續接收數據
  • 待該Follower恢復后,Follower會讀取本地磁盤記錄的上次的HW,并將log文件高于HW的部分截取掉,從HW開始向Leader進行同步
  • 等該Follower的LEO大于該Partition的HW,即Follower追上Leader之后,就可以重新加入ISR了。
  • 總結

    以上是生活随笔為你收集整理的大数据-kafka学习(三)——Kafka Broker的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。