同じ上で実行されている gRPC サービスにアクセスする場合サーバーを使用する場合、サービスごとに個別の接続を確立する必要はありません。単一の grpc.ClientConn を使用してすべてのサービスにアクセスできます。
接続を共有するには、目的のエンドポイントを使用して grpc.ClientConn を作成し、それを使用したいサービスごとに pb.New*Client() 関数を実行します。これにより、同じ接続を利用できるようになります。
<code class="go">cc, err := grpc.Dial("localhost:6000", grpc.WithInsecure()) if err != nil { log.Fatal(err) } c1 := pb.NewSubscriberServiceClient(cc) c2 := pb.NewDropperServiceClient(cc)</code>
複数のサービスのクライアント側 gRPC 機能を組み合わせるインターフェイスを作成できますが、 pb.go で生成されたコードは、すべての重要な操作を処理します。新しい機能の実装は、特定のカスタム ロジックにのみ必要です。
一意のメソッド名を持つサービスの場合は、クライアントをバンドルするための便利な構造体を定義できます。
<code class="go">type SubscriberDropper struct { pb.SubscriberServiceClient pb.DropperServiceClient }</code>
ネットワーク経由で複数の gRPC サービスにアクセスする単一接続により、クライアント側の実装が簡素化され、コードの保守性が向上します。
以上が単一の接続で複数の gRPC サービスにアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。