A tour of gRPC:07 - gRPC bidirectional straming 双向流
data:image/s3,"s3://crabby-images/9ff96/9ff9698348db1716c0b9413963998ef239e7e5f4" alt="A tour of gRPC:07 - gRPC bidirectional straming 双向流"
go bidirectional-streaming call
1. 修改 laptop_service.proto 添加 ReteLaptop 相关内容,运行 make clean 、make gen 进行 代码生成
data:image/s3,"s3://crabby-images/24bda/24bda3db787de7ba2e0f55d9ffac5c116d5889b0" alt=""
2. rating_store.go 中编写和评分相关的内容
data:image/s3,"s3://crabby-images/ffb16/ffb1617b64adeb78ff64ca641dbe2e1121dac4f6" alt=""
3. 在 laptop_server.go 中实现 添加 RatingStore 并修初始化函数(修改之前单元测试中为 ratingStore 添加 nil 值)实现服务端 RateLaptop 内容
data:image/s3,"s3://crabby-images/86f4c/86f4c38d849a3164cac3cf5fb0141b0b722307f0" alt=""
4. 在 sample 包 generator 中增加一个生成 rating 的功能
data:image/s3,"s3://crabby-images/33d13/33d1357a4700645bc71d98e26b73b2748f9d99b3" alt=""
5. 在 client/main.go 中实现 rateLaptop
data:image/s3,"s3://crabby-images/088df/088df8ed90530ea44e4942f8494b53acb3392075" alt=""
6. 编写一个单元测试
data:image/s3,"s3://crabby-images/50fff/50fff4fb43206c3006f6c5fb2b146067f6f13bad" alt=""
运行一下单元测试
data:image/s3,"s3://crabby-images/ad374/ad374463f972a79bd270c9576b6e409d3da6599d" alt=""
运行一下 server 和 client 进行测试
data:image/s3,"s3://crabby-images/35ba9/35ba9861ef2184fa998057bbb1c497a2cdbc9c3c" alt=""
可以看到,client 发送完 3 条 create laptop 后,server 返回了评分的提示,此时 client 再次发送 y 后, server 接收到后会进行评分,并进行返回。也就是说,client 和 server 在一次连接中都发送了多次消息。
Java bidirectional-streaming call
1. 拷⻉ gRPC go bidirectional-straming 中的 laptop_service.proto 运行 mvn clean compile 生成最新的代码
2. 新建一个 Rating 实体类
data:image/s3,"s3://crabby-images/ddc8b/ddc8b11e5b37e38a2622623781a9382fb46479cf" alt=""
3. 新建一个 RatingStore 接口
data:image/s3,"s3://crabby-images/3b39c/3b39c3a1baba27acb426938fecfbfd92ee96d566" alt=""
4. 新建一个 InMemoryRatingStore 实现 RatingStore
data:image/s3,"s3://crabby-images/e2481/e2481600b7490cbff0c2c60834b0b8cdf3db89b2" alt=""
5.编写一个单元测试进行测试
data:image/s3,"s3://crabby-images/197f4/197f46a8baddb905fb15f2026ea279355aa30e01" alt=""
data:image/s3,"s3://crabby-images/2f3c8/2f3c842a65ce0bc064ab0af328c9e262312cdf59" alt=""
单元测试通过,结果符合预期
6. 在 LaptopService 中实现 RatingStore 相关内容,并修改 LaptopServer 中使用 LaptopService 方法的地方。
data:image/s3,"s3://crabby-images/41d65/41d65b2d0ede58bbc08b30aad975a9e56168ab93" alt=""
7. 接下来实现客户端,在 Generator 中添加一个新随机生成分数的方法
data:image/s3,"s3://crabby-images/d1fdd/d1fdd3db3457bbc86aacd219742f461d16def80e" alt=""
8. 在客户端编写一个调用 rating 的方法
data:image/s3,"s3://crabby-images/15c90/15c90b06c4cf8cd554148aab3acc13eb00277db7" alt=""
9. 运行 server 和 client 进行测试
data:image/s3,"s3://crabby-images/e3d2a/e3d2ad8604cc553e4af5dff06759b0e63fc8bbcb" alt=""
同上,可以看到,client 发送完 3 条 create laptop 后,server 返回了评分的提示,此时 client 再次发送 y 后,server 接收到后会进行评分,并进行返回。也就是说,client 和 server 在一次连接中都发送了多次 消息。
跨语言的 bindirectional-streaming 测试
最后,来到了我们的熟悉的跨语言测试环节
我们先使用 Java Server 和 go client 进行测试
data:image/s3,"s3://crabby-images/54812/548124595301b92f1a0aa1ffafdf556ad17e6911" alt=""
测试结果符合预期。
我们再反顾来使用 go Server 和 Java client 进行测试
data:image/s3,"s3://crabby-images/05afb/05afbbbaf3ce4c1ba6bd397e01c5199a19bfc5af" alt=""
效果符合预期
data:image/s3,"s3://crabby-images/edcf1/edcf15ef1739088f0f8a28ab58493f75b840a1a0" alt=""
data:image/s3,"s3://crabby-images/f5887/f58872a10fabef0e991e69a3967676e268a6d47b" alt=""
data:image/s3,"s3://crabby-images/b2508/b2508c77f42548cb9430fe1205ae22d3b59e32ba" alt=""
版权声明: 本文为 InfoQ 作者【BUG侦探】的原创文章。
原文链接:【http://xie.infoq.cn/article/00f2032fedd862fcd0285a880】。文章转载请联系作者。
评论