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 の設定
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 最適化担当者の日常業務に欠かせない部分です。これは、...
A5 Webmaster Network(www.admin5.com)は5月21日、ビデオアプリケ...
以前は非常に混乱していて、SEO が限界に達したと感じていました。成功事例があり、関連する開発力、デ...
lcayun/Leicaクラウドサーバーメーカーは、国内認定のエンタープライズサーバーマーチャントで...
2023年11月、Volcano Engineは北京、上海、深センでVolcano Engineパブ...
eName.cnは4月15日、昨年ドメイン名投資家のAbu氏が海外から買い戻した「life」ドメイン...
インターネットの発展は、確かに多くの産業に発展の春をもたらしました。例えば、伝統的な手作りのスクエア...
ウェブサイトページの最適化は、ウェブページの最適化とも呼ばれ、ウェブページのプログラム、コンテンツ、...
アリババは昨年7月以来、小米と天天洞庭の戦略的買収を相次いで完了し、音楽市場での配置を急速に完成させ...
OpenStack Foundation の COO は、エッジ コンピューティングはクラウド コン...
onetechcloud は現在、香港 CN2 回線、日本 CN2 回線、米国トリプルネットワーク ...
SEO環境において、フレンドリーリンクはウェブサイト間の相互プロモーションの基本的な手段から、ウェブ...
[51CTO.comからのオリジナル記事] デジタルトランスフォーメーションが加速するにつれ、ビジネ...
ウェブサイトのタイトルと説明は、ウェブサイトのメタ情報の中で最も重要な内容です。ほとんどのウェブサイ...