.NET で Kafka を使用する方法

.NET で Kafka を使用する方法

[[386220]]

この記事はWeChatの公開アカウント「Coder Reading」から転載したもので、著者はCoder Readingです。この記事を転載する場合は、Coder Reading の公開アカウントにご連絡ください。

Kafka は、オープンソースで分散型、スケーラブル、高性能なパブリッシュ/サブスクライブ メッセージング ミドルウェアです。大量のデータを処理するシステムを構築したい場合、Kafka は非常に良い選択肢になります。この記事では、Kakfa に基づいてパブリッシュ/サブスクライブ プログラムを構築する方法について説明します。

Kafka アーキテクチャ

このセクションでは、まず Kafka のインフラストラクチャと関連する用語について見てみましょう。一般的に、Kafka は次のコンポーネントで構成されています。

  • Kafka クラスター 1 つ以上のサーバーで構成されるクラスター
  • プロデューサー メッセージを公開するために使用されるコンポーネント。
  • コンシューマー メッセージを取得して処理するコンポーネント。
  • ZooKeeper は、分散環境内の各ノードの構成情報を保存するのによく使用される集中型調整コンポーネントです。

Kafka では、データの基本単位はキーと値のペアであるメッセージです。 Kafkaはすべてのメッセージをbyte[]に変換します。プロデューサー、コンシューマー、クラスターはすべて TCP プロトコルを使用して通信することに注意してください。 Kafka クラスター内の各マシンはブローカーと呼ばれます。クラスターにマシンを簡単に追加して、容量の水平拡張を実現できます。

次の図は、Kafka の基本的なアーキテクチャを示しています。

Kafka のトピックはメッセージの論理的なコレクションを表します。わからない場合は、トピックをカテゴリとして考えることができます。カテゴリの下には自然に分類されたメッセージがあり、これらのメッセージはプロデューサーによって生成されます。

Kafka サーバーには 1 つ以上のトピックが含まれ、各トピックには 1 つ以上のパーティションを含めることができます。パーティションは、順序付けられたメッセージのシーケンスとして定義されます。パーティションが Kafka の動的拡張の鍵となることは注目に値します。つまり、パーティションを複数の Kafka サーバーに分散できます。具体的な操作プロセスは、Kafka のプロデューサーが指定されたトピックにメッセージをプッシュし、トピックをサブスクライブしているコンシューマーがメッセージを取得できることです。

Kafka と RabbitMQ の比較

Kafka と RabbitMQ はどちらも非常に人気のあるオープンソースのメッセージ ミドルウェアです。では、RabbitMQ ではなく Kakfa を選択すべきなのはどのような場合でしょうか?主な考慮事項は次のとおりです。

  • RabbitMQ は、高性能言語 Erlang で書かれています。豊富なルーティング メカニズムと強力なメッセージ確認メカニズムを備えています。 RabbitMQ は視覚的な WebUI インターフェイスも提供しており、これを使用して RabbitMQ の実行ステータスを監視できます。ただし、大規模な展開が必要な場合、RabbitMQ は Kafka ほど適していません。Kafka はパーティションを追加することによってのみ拡張できるためです。
  • RabbitMQ クラスターには典型的なスプリットブレイン問題があり、個別のプラグイン サポート (フェデレーション) を使用する必要があります。
  • Kafka はパフォーマンスにおいて RabbitMQ をはるかに上回ります。単一ノードの Kafka は 1 秒あたり 100,000 件のレコードを処理できますが、RabbitMQ は 1 秒あたり約 20,000 件のレコードしか処理できません。

生産者と消費者の育成

このセクションでは、Kafka のプロデューサーとコンシューマーを構築する方法について説明します。これには、それぞれの役割を果たす 2 つのコンソール プログラムを構築する必要があります。 nuget を使用して kafka-net をインストールできます。コマンドは次のとおりです。

  1. インストールパッケージ kafka-net

プロデューサーコンソールを構築する

  1. 静的void Main(文字列[] 引数)
  2. {
  3. 文字列ペイロード = "Kafka へようこそ!" ;
  4. 文字列トピック = "IDGTestTopic" ;
  5. メッセージ msg = 新しいメッセージ(ペイロード);
  6. URI uri = new Uri( "http://localhost:9092" );
  7. var options = new KafkaOptions(uri);
  8. var router = 新しい BrokerRouter(オプション);
  9. var client = 新しいプロデューサー (ルーター);
  10. client.SendMessageAsync(トピック、新しいリスト<Message> { msg }).Wait();
  11. コンソールの行を読み取ります。
  12. }

消費者向けコンソールを構築する

  1. 静的void Main(文字列[] 引数)
  2. {
  3. 文字列トピック = "IDGTestTopic" ;
  4. URI uri = new Uri( "http://localhost:9092" );
  5. var options = new KafkaOptions(uri);
  6. var router = 新しい BrokerRouter(オプション);
  7. var コンシューマー = 新しいコンシューマー(新しい ConsumerOptions(トピック、ルーター));
  8. foreach (consume.Consume()内の変数メッセージ)
  9. {
  10. Console.WriteLine(Encoding.UTF8.GetString(message.Value));
  11. }
  12. コンソールの行を読み取ります。
  13. }

最後に、プロデューサー プログラムとコンシューマー プログラムを順番に起動すると、「Welcome to Kafka!」というメッセージが表示されます。コンシューマー コンソールに表示されます。

実際、オープンソースの世界には、RabbitMQ、MSMQ、IBM MQ Series など、メッセージ ミドルウェアが数多く存在します。現在、Kafka はメッセージ ミドルウェアであるだけでなく、ビッグ データ用のストリーミング処理プラットフォームでもあります。 Kafka は、IoT プログラム、ログ集約、その他の低レイテンシで強力なメッセージ保証のシナリオでもよく使用されます。アプリケーションに高速かつスケーラブルなメッセージ ミドルウェアが必要な場合は、Kafka が最適な選択肢となります。 Kafka に関する記事を後ほど共有します。

ネットでApache Kafkaメッセージングを使用する方法

<<:  IoT アナリティクス: 製造業者の 3 分の 1 がソフトウェアをクラウドに移行する予定

>>:  分散ストレージの技術動向(I):3つのレプリカの欠点

推薦する

「中国Vバレー」馬欄山がグリーンデータセンターを建設、アリババクラウドの液体冷却技術が初めて輸出

サーバーを水に浸す単相浸漬液冷却技術は、グリーン データ センターの新しい標準になりつつあります。 ...

友好的なリンクの交換から、私たちは現実的な人間になり、正式かつ規則的にウェブサイトを運営する方法を知ることができます。

ウェブマスターの間では、「コンテンツは王、外部リンクは皇帝、内部リンクは側室、コードは将軍、キーワー...

K-edされた観光ウェブサイトの分析例

みなさんこんにちは、私はShi Touです。今朝早く、誰かがQQで私を追加しているのを見ました。この...

ピンドゥオドゥオは商品フローに基づいた「今日頭条」か?

今週、Pinduoduoは2018年第4四半期および通年の監査されていない財務報告書を発表しました。...

ローカルウェブサイトの価値についての議論 ローカルウェブサイト投資に関する9つの質問と回答

ローカルウェブサイトは中国のインターネットの独特な領域であり、まだ初期段階にあります。この分野の価値...

インターネット企業の新しいウェブサイトの運営に関する3つの考察: 2013年のSEOへの道

本社は新たにネットワーク会社を設立しました。実は、2010年の時点ですでに強力なネットワークチームが...

ウェブマスターネットワークからの毎日のレポート:分類されたウェブサイトが問題を抱えており、Sinaが毎年恒例のホットリストを発表

1. 今年の共同購入の売上高は210億ドルを超えると予想されており、定期的な割引には目新しさがない独...

なぜ k8s はクラウド時代のオペレーティング システムと呼ばれるのでしょうか?

[[420872]]過去 2 年間で、Kubernetes は Swarm と Mesos を打ち負...

5分でわかるKubernetes: すべてのコンポーネントを簡単に理解

以前、サービスメッシュに関する一連のコンテンツについて触れました。しかし、アプリケーション サービス...

BuzzFeedの成功物語: なぜGoogleと広告欄を放棄したのか

BuzzFeedのウェブサイトテンセントテクノロジーロイスは12月13日に報告した。 [ケーススタデ...

クラウド コンピューティングの 2 つの大きな謎: Alibaba Cloud はトップに到達できるか?他の人に残された時間はどれくらいでしょうか?

ガートナーは2021年4月21日、2020年の世界パブリッククラウドIaaS市場データを発表しました...

クラウド トラフィックを監視するための 7 つの QoS ベスト プラクティス

最近では、高性能マルチコア CPU、仮想化、高速でユビキタスなインターネット アクセスなどのテクノロ...

Ramnode - 新年プロモーション、OVZ と KVM が 25% オフ

新年が近づいてきました。ramnode から新年の贈り物が届きました。すべての SVZS と SKV...

SEO 最適化ランキングの摂動テスト

ウェブサイトの特定のキーワードのランキングが安定しているかどうかをどのように判断すればよいでしょうか...