Lors de l'accès aux services gRPC exécutés sur le même serveur, il est inutile d'établir des connexions distinctes pour chaque service. Un seul grpc.ClientConn peut être utilisé pour accéder à tous les services.
Pour partager une connexion, créez un grpc.ClientConn en utilisant le point de terminaison souhaité et transmettez-le au Fonctions pb.New*Client() pour chaque service que vous souhaitez utiliser. Cela leur permet d'utiliser les mêmes connexions.
<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>
Bien que vous puissiez créer une interface pour combiner les fonctions gRPC côté client pour plusieurs services, le le code généré dans pb.go gère toutes les opérations essentielles. La mise en œuvre de nouvelles fonctionnalités n'est nécessaire que pour une logique personnalisée spécifique.
Pour les services avec des noms de méthode uniques, vous pouvez définir une structure pratique pour regrouper leurs clients :
<code class="go">type SubscriberDropper struct { pb.SubscriberServiceClient pb.DropperServiceClient }</code>
Accéder à plusieurs services gRPC via un une connexion unique simplifie la mise en œuvre côté client et améliore la maintenabilité du code.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!