java 版 gRPC 实战之三:服务端流
欢迎访问我的 GitHub
这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos
关于 gRPC 定义的四种类型
本文是《java 版 gRPC 实战》系列的第三篇,前文咱们实战体验了简单的 RPC 请求和响应,那种简单的请求响应方式其实只是 gRPC 定义的四种类型之一,这里给出《gRPC 官方文档中文版》对这四种 gRPC 类型的描述:
简单 RPC:客户端使用存根(stub)发送请求到服务器并等待响应返回,就像平常的函数调用一样;
服务器端流式 RPC:客户端发送请求到服务器,拿到一个流去读取返回的消息序列。 客户端读取返回的流,直到里面没有任何消息;(即本篇内容)
客户端流式 RPC:客户端写入一个消息序列并将其发送到服务器,同样也是使用流。一旦 客户端完成写入消息,它等待服务器完成读取返回它的响应;
双向流式 RPC:是双方使用读写流去发送一个消息序列。两个流独立操作,因此客户端和服务器 可以以任意喜欢的顺序读写:比如, 服务器可以在写入响应前等待接收所有的客户端消息,或者可以交替 的读取和写入消息,或者其他读写的组合。 每个流中的消息顺序被预留;
本篇概览
本篇是服务端流类型的 gRPC 服务实战,包括以下内容:
开发一个 gRPC 服务,类型是服务端流;
开发一个客户端,调用前面发布的 gRPC 服务;
验证;
不多说了,开始上代码;
源码下载
本篇实战中的完整源码可在 GitHub 下载到,地址和链接信息如下表所示(https://github.com/zq2599/blog_demos):
这个 git 项目中有多个文件夹,《java 版 gRPC 实战》系列的源码在 grpc-tutorials 文件夹下,如下图红框所示:
grpc-tutorials 文件夹下有多个目录,本篇文章对应的服务端代码在 server-stream-server-side 目录下,客户端代码在 server-stream-client-side 目录下,如下图:
开发一个 gRPC 服务,类型是服务端流
首先要开发的是 gRPC 服务端,一共要做下图所示的七件事:
打开 grpc-lib 模块,在 src/main/proto 目录下新增文件 mall.proto,里面定一个了一个 gRPC 方法 ListOrders 及其入参和返回对象,内容如下,要注意的是返回值要用关键字 stream 修饰,表示该接口类型是服务端流:
双击下图红框位置的 generateProto,即可根据 proto 生成 java 代码:
新生成的 java 代码如下图红框:
在父工程 grpc-turtorials 下面新建名为 server-stream-server-side 的模块,其 build.gradle 内容如下:
新建配置文件 application.yml:
启动类:
接下来是最关键的 gRPC 服务,代码如下,可见 responseObserver.onNext 方法被多次调用,用以向客户端持续输出数据,最后通过 responseObserver.onCompleted 结束输出:
至此,服务端开发完成,咱们再开发一个 springboot 应用作为客户端,看看如何远程调用 listOrders 接口,得到 responseObserver.onNext 方法输出的数据;
开发一个客户端,调用前面发布的 gRPC 服务
客户端模块的基本功能是提供一个 web 接口,其内部会调用服务端的 listOrders 接口,将得到的数据返回给前端,如下图:
在父工程 grpc-turtorials 下面新建名为 server-stream-client-side 的模块,其 build.gradle 内容如下:
应用配置信息 application.yml 内容如下,可见是端口和 gRPC 服务端地址的配置:
服务端的 listOrders 接口返回的 Order 对象里面有很多 gRPC 相关的内容,不适合作为 web 接口的返回值,因此定义一个 DispOrder 类作为 web 接口返回值:
平淡无奇的启动类:
重点来了,GrpcClientService.java,里面展示了如何远程调用 gRPC 服务的 listOrders 接口,可见对于服务端流类型的接口,客户端这边通过 stub 调用会得到 Iterator 类型的返回值,接下来要做的就是遍历 Iterator:
最后做一个 controller 类,对外提供一个 web 接口,里面会调用 GrpcClientService 的方法:
至此,编码完成,开始验证
验证
启动 server-stream-server-side,启动成功后会监听 9989 端口:
启动 server-stream-client-side,再在浏览器访问:http://localhost:8081/?name=Tom ,得到结果如下(firefox 自动格式化 json 数据),可见成功地获取了 gRPC 的远程数据:
至此,服务端流类型的 gRPC 接口的开发和使用实战就完成了,接下来的章节还会继续学习另外两种类型;
欢迎关注 InfoQ:程序员欣宸
版权声明: 本文为 InfoQ 作者【程序员欣宸】的原创文章。
原文链接:【http://xie.infoq.cn/article/1b4e56202bd23cb702dea10dc】。文章转载请联系作者。
评论