为什么每个grpc服务都需要拨不同的套接字?
你不知道 您可以创建一个
grpc.ClientConn并将其传递给多个
pb.New*Client()功能,它们将共享相同的连接。
func main() { cc, err := grpc.Dial("localhost:6000", grpc.WithInsecure()) if err != nil { log.Fatal(err) } c1 := pb.NewSubscriberServiceClient(cc) c2 := pb.NewDropperServiceClient(cc)}然后使用此接口为每个服务实现客户端grpc函数,而不是为每个服务创建新的结构
pb.go文件中生成的代码完成了执行RPC所需的一切。除非您有特殊的逻辑要在每次执行呼叫时自动发生,否则您不必实现任何客户端功能。
如果这两个服务具有唯一的方法名称,则可以将它们放在相同的结构中,这样就不必为了小幅方便而分别使用它们:
type SubscriberDropper struct { pb.SubscriberServiceClient pb.DropperServiceClient}func main() { // ... as above ... sd := &SubscriberDropper{c1, c2}}


