[系列] Go gRPC 调试工具
程序员文章站
2022-05-22 20:43:47
[TOC] 概述 最近这段时间工作挺忙的,发现已经 3 周没更文了... 感谢你们还在,今天给大家分享一款 gRPC 的调试工具。 进入正题。 当我们在写 HTTP 接口的时候,使用的是 Postman 进行接口调试,那么在写 gRPC 接口的时候,有没有类似于 Postman 的调试工具呢? 这是 ......
目录
概述
最近这段时间工作挺忙的,发现已经 3 周没更文了...
感谢你们还在,今天给大家分享一款 grpc 的调试工具。
进入正题。
当我们在写 http 接口的时候,使用的是 postman 进行接口调试,那么在写 grpc 接口的时候,有没有类似于 postman 的调试工具呢?
这是有的。
咱们一起看下 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
我原来写过 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; }
很简单,这个大家一看就知道了。
- service name 为 listen.listen
- method name 为 listendata
再看下 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
直接返回。
源码地址:
启动服务
cd listen && go run main.go
服务启动成功后,等待使用。
grpcui 使用
安装
根据官方 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 也都会显示出来的,去试试吧。