gRPC 服务开发和接口测试初探【Go】
之前写过了Grpc服务开发和接口测试初探【Java】,中间耽搁了一些时间,Go 版本的 gRPC 测试开发实践才有时间学习使用。其中也是由于自己 Go 语言不够熟悉导致的。之前有段时间想暂时放弃 Go 语言的学习,导致了 Go 的生疏,原因是从Groovy到Java性能。
前置
回归正题,Go 语言版本的 gRPC 实践相对 Java 来说是比较简单的,但是总体的工具链是比较复杂的,可能是因为 Go 生态目前相比 Java 还是比较匮乏吧。下面我先简述一下大致的步骤:
安装 Go 语言环境和 IDE:如 GoLand
安装 protoc-gen-go,或者安装 gofast,据称后者性能更高且更复杂
安装 gRPC,这里有坑,可能是网络,大家自行解决
生成 Demo 代码,命令和参数取决于使用哪种工具
以上步骤亲自操作可能会遇到一些小问题,我本人搜到的教程什么的也是乱七八糟,踩了一些坑。我没有整理出一个亲自实践之后的可行的教程,原因有二:
我这可行的,肯定不是放之四海皆准
解决问题也是学习提升的一部分,不能越俎代庖
proto
Go 语言的 gRPC 的proto
编写跟 Java 大致一致,只有一个报名的参数不太一样。下面是我的Hello.proto
内容:
这里主要go_package
网上搜到的配置方式有些不一样,我没有全都尝试,大家在搜索的资料时候,尽量先看看syntax
这个参数的值,以及文章教程写作的时间,如果距离现在太久了,我建议直接关掉。搜索引擎有过滤功能,可以过滤掉过时的教程。
编码
这里 Go 语言 gRPC 的一点优势,就是在一个项目中即可实现,Java 需要先弄一个 SDK 这样。Go 语言的 gRPC 的代码可以通过生成代码命令中的参数实现指定路径。我是放在了和proto
文件的同级目录。
服务端
服务端代码也是比较格式化的内容,如下:
其中 pb.RegisterHelloServiceServer(s, &Ser{})
如果报错,请检查自己安装的工具protoc-gen-go
或者protoc-gen-gofast
版本,一般提取报错message
搜索也能得到解决办法。
客户端
下面是客户端的代码,由于学艺不精,其中大部分参数的含义目前我也不是很清楚,特别是基于stream
的请求响应的方式使用。后面我先把 Java 的学完,再回过头来看 Go 的,按照这个顺序学习和分享。
控制台
服务端输出:
忘记打日志了。没有输出
客户端输出:
Go 语言的 gRPC 测试开发实践已经完事儿,大概率上我不会在工作中使用 Go 作为主力 gRPC 测试语言,后面测试实践内容还是会以 Java 为主。
Have Fun ~ Tester !
版权声明: 本文为 InfoQ 作者【FunTester】的原创文章。
原文链接:【http://xie.infoq.cn/article/b55139a9f0db8e915d0858803】。文章转载请联系作者。
评论