gRPC服务端创建流程是怎么样的
小编给大家分享一下gRPC服务端创建流程是怎么样的,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
gRPC 服务端创建关键流程分析:
NettyServer 实例创建:
gRPC 服务端创建,首先需要初始化 NettyServer,它是 gRPC 基于 Netty 4.1 HTTP/2 协议栈之上封装的 HTTP/2 服务端。
NettyServer 实例由 NettyServerBuilder 的 buildTransportServer 方法构建,
NettyServer 构建完成之后,监听指定的 Socket 地址,即可实现基于 HTTP/2 协议的请求消息接入。
绑定 IDL 定义的服务接口实现类:
gRPC 与其它一些 RPC 框架的差异点是服务接口实现类的调用并不是通过动态代理和反射机制,而是通过 proto 工具生成代码,
在服务端启动时,将服务接口实现类实例注册到 gRPC 内部的服务注册中心上。
请求消息接入之后,可以根据服务名和方法名,直接调用启动时注册的服务实例,而不需要通过反射的方式进行调用,性能更优。
gRPC 服务实例(ServerImpl)构建:
例如 Netty 的线程池资源、gRPC 的线程池、内部的服务注册类(InternalHandlerRegistry)等,
ServerImpl 负责整个 gRPC 服务端消息的调度和处理,
创建 ServerImpl 实例过程中,会对服务端依赖的对象进行初始化,
ServerImpl 初始化完成之后,就可以调用 NettyServer 的 start 方法启动 HTTP/2 服务端,接收 gRPC 客户端的服务调用请求。
以上是"gRPC服务端创建流程是怎么样的"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!