Zookeeper における Kafka のデータ構造を完全に説明する図

Zookeeper における Kafka のデータ構造を完全に説明する図

[[421933]]

kafka_2.8.0 より前では、kafka を実行するには依然として zookeeper に依存する必要があり、「ブローカー登録情報」、「トピック情報」、「運用および保守の一時情報」、「構成情報」などの kafka 内の多くのデータが zk に保存されていました。

以下では、写真を使用して、Zookeeper における Kafka の全体像を紹介します。ぜひ集めてみることをお勧めします!!!

一枚の写真がすべてを物語る

Zookeeper における Kafka のデータ構造

1/クラスター

01- /cluster/id 永続データノード

クラスター ID 最初のブローカーが起動すると、/cluster/id が存在しないことがわかり、その cluster.id 構成が zk に書き込まれます。現在の zk がどのクラスターに属しているかをマークします。他のブローカーが後で起動すると、データが取得されます。データが自身の構成と一致していないことが判明した場合;例外がスローされ、同じクラスターに参加しません。データ例: {"version":"1","id":"0"}

2/controller_epoch 永続データノード

コントローラーの選出時間。

3/コントローラ一時データノード

現在のコントローラー ロールの BrokerId、データ例: {"version":1,"brokerid":0,"timestamp":"1624415590383"} このノードを削除すると、すぐに再選出がトリガーされます

4/ログディレクトリイベント通知

zk データには、シリアル番号永続ノードであるノード /log_dir_event_notification/ があります。 kafka でのこのノードの役割は次のとおりです: ブローカーの LogDir で例外が発生した場合 (ディスクの損傷、ファイルの読み取りおよび書き込みの失敗など)、子ノード /log_dir_event_notification/log_dir_event_serial 番号を zk に追加します。コントローラーはこのノードの変更を監視した後、ブローカーに LeaderAndIsrRequest リクエストを送信します。その後、オフラインレプリカに対していくつかのフォローアップ操作を実行します

5/isr_change_notification/log_dir_event_{シーケンス番号}

Isrが変更されると、このノードコントローラは変更を監視するように書き込まれます。

6/管理者

01 -/admin/delete_topics/{topicName} 永続ノード、削除するトピック

このノードが存在するということは、現在のトピックを削除する必要があることを意味します。

02 - /admin/reassign_partitions 永続データノード

このノードが存在する場合、データ移行が現在進行中であり、その中のデータは移行中の構成サンプル データであることを意味します。

7/ブローカー

01 -/ブローカー/seqid

/brokers/seqid: グローバルシーケンス番号にデータがありません。主にノードの dataVersion 情報をグローバル シーケンス番号として使用します。

Kafka の機能: BrokerId を自動的に生成は、主に brokerId を自動的に生成するために使用されます。クラスターが非常に大きい場合、brokerId の設定を繰り返すことはできず、1 つずつ設定するのは面倒です。ブローカーにBrokerIdを自動生成させることもできます

server.properties の設定

  1. ## Brokeridを自動生成するように設定する
  2. ブローカーID生成を有効にする= true  
  3. ## BrokerId<0 を設定します (>=0 の場合は、この構成が優先されます)
  4. ブローカーID=-1
  5. ## 構成の開始値を自動的に生成する
  6. 予約ブローカー最大ID =20000

BrokerIdの計算方法

ブローカーID = {reserved.broker.max.id} +/brokers/seqid.dataVersion

/brokers/seqid の dataVersion 値を取得するたびに、set メソッドを使用します。設定時はバージョンデータは取得されずに返されます。ノードデータを設定するたびに、バージョン情報が自動的に増加します。グローバル自動インクリメント ID が実装されます。

02 - /brokers/ids/{id} 一時データノード: オンラインブローカーID

すべてのオンラインブローカーはここにノードを登録します。オフラインになると自動的に削除されます。

03 - /brokers/topics/{topicName} 永続データノード

ストレージ トピック パーティション レプリカの割り当て情報。例: {"version":1,"partitions":{"0":[0]}}

/brokers/topics/{topicName}/{partition number}/state 永続データノード

指定されたパーティションのリーダーや isr などの情報を格納します。例: {"controller_epoch":203,"leader":0,"version":1,"leader_epoch":0,"isr":[0]}

この記事はWeChat公式アカウント「Shi Zhenzhen's Grocery Store」から転載したものです。下のQRコードからフォローできます。記事を転載する場合は、石真珍食料品店の公式アカウントまでご連絡ください。

<<:  コンテナを理解するには、まずその歴史から始めましょう

>>:  Dubbo 3.0サーバー露出の全プロセスの詳細な分析

推薦する

ロンドン五輪の放映権争いが終結、ポータルネットワークが生放送権の購入を断念

ロンドン五輪の開幕が近づき、国内のネットメディアの放映権をめぐる一大戦いが終結した。 「私の知る限り...

UAE VPS クラウド サーバー: estnoc、UAE データ センター、1Gbps 帯域幅、月額 10 ユーロから

UAE VPS と UAE クラウド サーバー、つまりアラブ首長国連邦の VPS とクラウド サーバ...

現在および将来にわたってマルチクラウド プロジェクトを予算内で維持する方法

Rightscale は、「2017 年のクラウドの現状」レポートで、約 85% の組織がマルチクラ...

電子商取引の背後にある価格戦争:今年20人以上の業界幹部が辞任

前回の急成長の後、2012年の電子商取引業界は「大魚が小魚を食べ、速い魚が遅い魚を蹴る」という統合の...

中央銀行は26の決済ライセンスの第6バッチを発行し、合計223のライセンスが発行されました。

昨日、新たに26件のサードパーティ決済「ライセンス」が発行されました。 「中国ビジネスデイリー」の記...

モノリシックモデルから分散モデルへと進化したKingsoft Cloudは、より高性能なデータベースDragonBaseを構築しました。

今日、情報は急速に発展し、多様化しており、現代の情報技術の 3 つの中核基盤の 1 つであるデータベ...

iPhoneからデータを盗まれないようにする方法

iPhone を使い始めてから、多くのユーザーはデータ消費量が非常に多いことに気づき、多くの場合、プ...

ウェブサイトリンクのテストのヒント

ウェブサイト上のウェブページは相互にリンクされており、ハイパーリンクと呼ばれるテキストやグラフィック...

オープンソース ソフトウェア成熟度評価レポート - 分散メッセージ ミドルウェア

1. 背景インターネット技術と金融技術の継続的な発展により、RPC から Web サービスへ、SOA...

フラッシュセール電子商取引の台頭:プラットフォームベースのベンダーが買収を開始する可能性

湘南のチ・ヨウレイVipshop がニューヨーク証券取引所の扉をノックしたとき、フラッシュセール モ...

crissic - KVM VPS 60% オフ/openv ダブルリソース

Crissic の VPS は G ポートをベースとしており、月間トラフィックを使い切ると自動的に ...

例の共有: 不安定なウェブサイトサーバーが Baidu スナップショットに与える影響

多くの SEO 担当者は、Web サイトを最適化する前に、上司に Web サイト用の安定したサーバー...

中小企業がネットワークマーケティングブランドを実現するための2つの勝利のポイント

中小企業がネットワークマーケティングブランドを実現するための2つの勝利のポイントはじめに: 企業が究...