(Kafka からの) メッセージ ストリームを使用し、REST API リクエストを読み取るサービスを Go で作成することは可能ですか?
質問内容
最近「大規模マイクロサービス間でのデータ共有」という記事を読みました
この図は非同期接続に関するものです。
私の記憶が正しければ、この図の 注文ページ このサービスは、Kafka からメッセージ ストリームを読み取ることができ、また、フロントエンド アプリケーションから REST API リクエストを読み取ることができるようです。
そこで、両方のタスクを同時に実行できるサービスを作成できないか考えています:
- Kafka からのメッセージ ストリームを読む
- REST API リクエストの読み取り
Go など、1 つのサービス内のみ。
これは良いアイデアですか?
回避策
はい、Kafka から消費して REST エンドポイントを公開する Go サービスを作成することは間違いなく可能です。ただし、これは理想的な設計上の決定ではありません。
Kafka ベースのストリーミング システムにより、プロデューサーとコンシューマー間の非同期通信が可能になります。ただし、REST API ベースのシステムは、呼び出し元と呼び出し先の間で同期的に通信します。
可用性の保証は、同期通信と同期モード通信で異なります。 Kafka Streams に基づくシステムには、REST API とは異なる可用性保証があります。ストリーミング システムでは、メッセージ処理のスループットに重点を置きますが、エンドツーエンドの同期通信では、遅延が主な懸念事項になります (呼び出し元が結果を取得するまで長時間待たされることは望ましくありません)。
この 2 種類のシステムを 1 つのサービスにまとめてしまうと、サービスの可用性がわかりにくくなります。さらに、サービスの非同期部分または同期部分が、反対側のノイズの多い隣人に影響を及ぼし、サービスが使用できなくなる可能性があります。
したがって、一般に、REST ベースの API と Kafka ストリームを 2 つの独立したサービスとして扱うことをお勧めします。
以上が(Kafka からの) メッセージ ストリームを使用し、REST API リクエストを読み取るサービスを Go で作成することは可能ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Golangは実際のアプリケーションに優れており、そのシンプルさ、効率性、並行性で知られています。 1)同時プログラミングはゴルチンとチャネルを通じて実装されます。2)柔軟なコードは、インターフェイスと多型を使用して記述されます。3)ネット/HTTPパッケージを使用したネットワークプログラミングを簡素化、4)効率的な同時クローラーを構築する、5)ツールと最高の実践を通じてデバッグと最適化。

GOのコア機能には、ガベージコレクション、静的リンク、並行性サポートが含まれます。 1. GO言語の並行性モデルは、GoroutineとChannelを通じて効率的な同時プログラミングを実現します。 2.インターフェイスと多型は、インターフェイスメソッドを介して実装されているため、異なるタイプを統一された方法で処理できます。 3.基本的な使用法は、関数定義と呼び出しの効率を示しています。 4。高度な使用法では、スライスは動的なサイズ変更の強力な機能を提供します。 5.人種条件などの一般的なエラーは、Getest Raceを通じて検出および解決できます。 6.パフォーマンス最適化Sync.Poolを通じてオブジェクトを再利用して、ゴミ収集圧力を軽減します。

GO言語は、効率的でスケーラブルなシステムの構築においてうまく機能します。その利点には次のものがあります。1。高性能:マシンコードにコンパイルされ、速度速度が速い。 2。同時プログラミング:ゴルチンとチャネルを介してマルチタスクを簡素化します。 3。シンプルさ:簡潔な構文、学習コストとメンテナンスコストの削減。 4。クロスプラットフォーム:クロスプラットフォームのコンパイル、簡単な展開をサポートします。

SQLクエリの結果の並べ替えについて混乱しています。 SQLを学習する過程で、しばしば混乱する問題に遭遇します。最近、著者は「Mick-SQL Basics」を読んでいます...

テクノロジースタックの収束とテクノロジーの選択の関係ソフトウェア開発におけるテクノロジーの選択、テクノロジースタックの選択と管理は非常に重要な問題です。最近、一部の読者が提案しています...

ゴーラン...

GO言語で3つの構造を比較および処理する方法。 GOプログラミングでは、2つの構造の違いを比較し、これらの違いを...

Goでグローバルにインストールされたパッケージを表示する方法は? GO言語で開発する過程で、GOはしばしば使用します...


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

Dreamweaver Mac版
ビジュアル Web 開発ツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 中国語版
中国語版、とても使いやすい
