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サーバー露出の全プロセスの詳細な分析

推薦する

変化し続けるインターネットで草の根ウェブサイトが生き残る方法

インターネットが誕生して20年近く経ちました。この20年のうち最初の10年は発展期でした。当時はイン...

SEOのヒント: ウェブサイト構造の最適化

SEO 最適化作業は、ウェブマスターや SEO 最適化担当者の日常業務に欠かせない部分です。これは、...

今日の話題: 生ぬるい短編ビデオはモバイル インターネットの次の爆発点となり得るか?

A5 Webmaster Network(www.admin5.com)は5月21日、ビデオアプリケ...

SEO 認知能力の向上についての簡単な話 - 私の 4 つの認知能力の向上を共有します

以前は非常に混乱していて、SEO が限界に達したと感じていました。成功事例があり、関連する開発力、デ...

lcayun/Leica Cloudはいかがでしょうか? US CN2 GIA クラウド サーバーのレビュー!

lcayun/Leicaクラウドサーバーメーカーは、国内認定のエンタープライズサーバーマーチャントで...

ジャイアントネットワークがshenghuo.comというドメイン名を58万元で購入したと報じられている。

eName.cnは4月15日、昨年ドメイン名投資家のAbu氏が海外から買い戻した「life」ドメイン...

SEO は難しいのに、なぜ多くの人が SEO に取り組むのでしょうか? 真実はどこにあるのでしょうか?

インターネットの発展は、確かに多くの産業に発展の春をもたらしました。例えば、伝統的な手作りのスクエア...

ウェブサイトページ最適化戦略

ウェブサイトページの最適化は、ウェブページの最適化とも呼ばれ、ウェブページのプログラム、コンテンツ、...

音楽著作権市場は再編に直面している

アリババは昨年7月以来、小米と天天洞庭の戦略的買収を相次いで完了し、音楽市場での配置を急速に完成させ...

エッジコンピューティングはクラウドコンピューティングを終わらせるでしょうか? OpenStackの噂:大丈夫

OpenStack Foundation の COO は、エッジ コンピューティングはクラウド コン...

onetechcloud: すべてのVPSが20%オフ、月額22元から、香港CN2、日本CN2、米国トリプルネットワークCN2、米国CN2高防御

onetechcloud は現在、香港 CN2 回線、日本 CN2 回線、米国トリプルネットワーク ...

友好的なリンク交換: Baidu の過大な重みにご注意

SEO環境において、フレンドリーリンクはウェブサイト間の相互プロモーションの基本的な手段から、ウェブ...

平安クラウドの「魔法の武器」は企業のR&Dライフサイクル全体を完全に保護します

[51CTO.comからのオリジナル記事] デジタルトランスフォーメーションが加速するにつれ、ビジネ...

ユーザーのニーズを満たすウェブサイトのタイトルと説明がSEOランキングに与える影響

ウェブサイトのタイトルと説明は、ウェブサイトのメタ情報の中で最も重要な内容です。ほとんどのウェブサイ...