概述
当我们在写 HTTP 接口的时候,使用的是 Postman 进行接口调试,那么在写 gRPC 接口的时候,有没有类似于 Postman 的调试工具呢?
这是有的。
咱们一起看下 grpcui
,源码地址:
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.
写一个 gRPC API
端口:9901
.proto
文件:
1 | syntax = "proto3"; // 指定 proto 版本 |
很简单,这个大家一看就知道了。
- Service name 为 listen.Listen
- Method name 为 ListenData
再看下 ListenData 方法:
1 | func (l *ListenController) ListenData(ctx context.Context, in *listen.Request) (*listen.Response, error) { |
这表示,将 Name
直接返回。
启动服务
1 | cd listen && go run main.go |
服务启动成功后,等待使用。
grpcui 使用
安装
根据官方 README.md
文档安装即可。
1 | go get github.com/fullstorydev/grpcui |
这时,在 $GOPATH/bin
目录下,生成一个 grpcui
可执行文件。
执行个命令,验证下:
1 | grpcui -help |
输出:
1 | Usage: |
表示安装成功了。
运行
1 | grpcui -plaintext 127.0.0.1:9901 |
这种情况下,加个反射就可以了,在 listen 的 main.go 新增如下代码即可:
1 | reflection.Register(s) |
在运行一次试试:
1 | grpcui -plaintext 127.0.0.1:9901 |
在浏览器中访问:http://127.0.0.1:63027/
到这,我们看到 Service name、Method name 都出来了,传输参数直接在页面上进行操作即可。
当发起 Request “Tom”,也能获得 Response “Tom”。
当然,如果这个服务下面有多个 Service name,多个 Method name 也都会显示出来的,去试试吧。