ホームページ >バックエンド開発 >Golang >単一の接続で複数の gRPC サービスにアクセスできますか?

単一の接続で複数の gRPC サービスにアクセスできますか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-11-04 03:36:02885ブラウズ

Can I Access Multiple gRPC Services over a Single Connection?

単一接続を介した複数の gRPC サービスへのアクセス

提供された例のように、複数の gRPC サービスが共有アドレスをリッスンする同じサーバー上に存在するシナリオでは、各サービスへの個別の接続を確立するのは冗長に思えるかもしれません。この記事の目的は、一般に個別の接続が必要な理由に対処し、単一の接続を利用して複数の gRPC サービスにアクセスする方法を検討することです。

複数の接続の必要性を排除する

ホストされているさまざまな gRPC サービスに効果的にアクセスするには同じサーバー上では、単一の gRPC クライアント接続を利用できます。このアプローチには、grpc.ClientConn オブジェクトを初期化し、それを個々のサービス クライアント ファクトリに渡して、同じ基盤となる接続を共有できるようにすることが含まれます。

func main() {
    cc, err := grpc.Dial("localhost:6000", grpc.WithInsecure())
    if err != nil {
        log.Fatal(err)
    }
    c1 := pb.NewSubscriberServiceClient(cc)
    c2 := pb.NewDropperServiceClient(cc)
}

Protobuf から生成されたコードを再利用する

pb.go ファイルで提供される生成された gRPC コードには、RPC を実行するために必要な機能がすべて含まれています。したがって、各呼び出し中に特定のロジックを自動的に実行する必要がない限り、追加のクライアント側実装は必要ありません。

利便性のためのインターフェイスの使用 (オプション)

サービスが異なる場合の場合

type SubscriberDropper struct {
    pb.SubscriberServiceClient
    pb.DropperServiceClient
}

func main() {
    // ... as above ...
    sd := &SubscriberDropper{c1, c2}
}

このアプローチを利用すると、冗長な接続確立を排除でき、その結果、gRPC のクライアント側実装がより効率的で最適化されます。アプリケーション。

以上が単一の接続で複数の gRPC サービスにアクセスできますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。