【发布时间】:2021-03-26 16:14:03
【问题描述】:
我试图在 gRPC、Protobuf 的上下文中理解侦听器、服务器和服务的概念。
让我们使用https://grpc.io/docs/languages/go/basics/ 上的示例作为参考。 这里有
- 听众:lis
- gRPC 服务器:grpcServer := grpc.NewServer()
- 服务:RouteGuide 服务
看来我们还可以在同一服务器上注册多个服务。
也就是说,除了RouteGuide Service,我们还可以说SomeOther Service,SomeOtherOther Service。
我们可以注册所有这三个,并期望服务器能够提供属于这三个服务(RouteGuide、SomeOther、SomeOtherOther)的方法。
假设 RouteGuide、SomeOther、SomeOtherOther 都有自己的特定于它们的 proto 文件。并且所有的原型都在同一个命名空间中(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)
似乎“服务器”一词在这里被过度使用了。 不仅是 grpcServer,RouteGuide、SomeOther 和 SomeOtherOther 也被称为 Server。
我正在尝试弄清楚如何建模或理解这些概念。
我们可以说,服务器gRPCServer通过监听器lis监听80端口,可以服务于它注册的三个服务RouteGuide、SomeOther、SomeOtherOther(gRPCServer)?
拥有一台服务器服务多个服务是否容易出错?
使用具有多个服务的一台服务器时要记住哪些注意事项?
【问题讨论】:
标签: go grpc grpc-go protobuf-go