gRPC は、分散システムを構築するための一般的なリモート プロシージャ コール (RPC) フレームワークです。複数の gRPC サービスにアクセスする場合、サービスごとにソケット接続を確立したくなります。ただし、このアプローチではリソースの使用効率が非効率になる可能性があります。
これに対処するために、gRPC を使用すると、単一の接続上で複数のサービスを多重化できます。これにより効率が向上するだけでなく、コードも簡素化されます。
単一ソケットのダイヤル
複数のサービスとの接続を確立するには、単一の gRPC.ClientConn オブジェクトを作成し、それを各サービスの New*Client() 関数に渡します。これらの関数は同じ接続を共有するため、単一のソケットを通じてすべてのサービスにアクセスできます。
<code class="go">// ... grpc service server implementation ... func main() { cc, err := grpc.Dial("localhost:6000", grpc.WithInsecure()) if err != nil { log.Fatal(err) } c1 := pb.NewSubscriberServiceClient(cc) c2 := pb.NewDropperServiceClient(cc) // ... }</code>
コードの重複を回避
それぞれに個別の構造体を作成する代わりにサービスでは、両方のサービスのクライアント インターフェイスを実装する単一の構造体を使用できます。この手法により、コードの重複が減り、コードが簡素化されます。
<code class="go">// ... grpc service server implementation ... type SubscriberDropper struct { pb.SubscriberServiceClient pb.DropperServiceClient } func main() { // ... as above ... sd := &SubscriberDropper{c1, c2} // ... }</code>
単一の接続上でサービスを多重化する機能を活用することで、コードを簡素化し、効率を高め、リソースのオーバーヘッドを削減できます。
以上が単一の接続で複数の gRPC サービスにアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。