sam*_*sam 5 go grpc grpc-go protobuf-go

我试图在 gRPC、Protobuf 的上下文中理解监听器、服务器和服务的概念。

让我们使用https://grpc.io/docs/languages/go/basics/上的示例作为参考。在这里我们有

  1. 听者:李
  2. gRPC 服务器:grpcServer := grpc.NewServer()
  3. 服务:RouteGuide服务

看来我们还可以将多个服务注册到同一服务器。

也就是说,除了RouteGuide Service,我们可以说SomeOther Service,SomeOtherOther Service。

我们可以注册所有这三个,并期望服务器能够提供属于这三个服务(RouteGuide、SomeOther、SomeOtherOther)的方法。

package
grpcServer := grpc.NewServer(opts...)

newRouteGuideService := pb.NewRouteGuideServer()
pb.RegisterRouteGuideServer(grpcServer, newRouteGuideService)

someOtherService := pb.NewSomeOtherServer()
pb.RegisterSomeOtherServer(grpcServer, someOtherService)

someOtherOtherService := pb.NewSomeOtherOtherServer()
pb.RegisterSomeOtherOtherService(grpcServer, someOtherOtherService)

 lis, err := net.Listen("tcp", fmt.Sprintf("localhost:%d", 80))
grpcServer.Serve(lis)

可以说,Server 一词在这里显得过重了。不仅是grpcServer,RouteGuide、SomeOther、SomeOtherOther也被称为Servers。

我试图弄清楚如何建模或理解这些概念。

gRPCServerlisgRPCServer