最近这段时间工做挺忙的,发现已经 3 周没更文了...github
感谢大家还在,今天给你们分享一款 gRPC 的调试工具。api
进入正题。浏览器
当咱们在写 HTTP 接口的时候,使用的是 Postman 进行接口调试,那么在写 gRPC 接口的时候,有没有相似于 Postman 的调试工具呢?tcp
这是有的。工具
我们一块儿看下 grpcui
,源码地址:ui
https://github.com/fullstorydev/grpcui调试
看下官方描述:日志
grpcui is a command-line tool that lets you interact with gRPC servers via a browser. It's sort of like Postman, but for gRPC APIs instead of REST.code
我原来写过 Demo,能够直接用原来写的 listen 项目。
端口:9901
.proto
文件:
syntax = "proto3"; // 指定 proto 版本 package listen; // 指定包名 // 定义服务 service Listen { // 定义方法 rpc ListenData(Request) returns (Response) {} } // Request 请求结构 message Request { string name = 1; } // Response 响应结构 message Response { string message = 1; }
很简单,这个你们一看就知道了。
再看下 ListenData 方法:
func (l *ListenController) ListenData(ctx context.Context, in *listen.Request) (*listen.Response, error) { return &listen.Response{Message : fmt.Sprintf("[%s]", in.Name)}, nil }
这表示,将 Name
直接返回。
源码地址:
https://github.com/xinliangnote/go-jaeger-demo/tree/master/listen
cd listen && go run main.go
服务启动成功后,等待使用。
根据官方 README.md
文档安装便可。
go get github.com/fullstorydev/grpcui go install github.com/fullstorydev/grpcui/cmd/grpcui
这时,在 $GOPATH/bin
目录下,生成一个 grpcui
可执行文件。
执行个命令,验证下:
grpcui -help
输出:
Usage: grpcui [flags] [address] ......
表示安装成功了。
grpcui -plaintext 127.0.0.1:9901 Failed to compute set of methods to expose: server does not support the reflection API
这种状况下,加个反射就能够了,在 listen 的 main.go 新增以下代码便可:
reflection.Register(s)
在运行一次试试:
grpcui -plaintext 127.0.0.1:9901 gRPC Web UI available at http://127.0.0.1:63027/
在浏览器中访问:http://127.0.0.1:63027/
到这,咱们看到 Service name、Method name 都出来了,传输参数直接在页面上进行操做便可。
当发起 Request "Tom",也能得到 Response “Tom”。
固然,若是这个服务下面有多个 Service name,多个 Method name 也都会显示出来的,去试试吧。