使用 Grpcurl 通過命令行訪問 gRPC 服務
一般情況下測試 gRPC 服務,都是通過客戶端來直接請求服務端。如果客戶端還沒準備好的話,也可以使用 BloomRPC 這樣的 GUI 客戶端。
如果環(huán)境不支持安裝這種 GUI 客戶端的話,那么有沒有一種工具,類似于 curl 這樣的,直接通過終端,在命令行發(fā)起請求呢?
答案肯定是有的,就是本文要介紹的 grpcurl。
gRPC Server
首先來寫一個簡單的 gRPC Server:
- syntax = "proto3";
- package proto;
- // The greeting service definition.
- service Greeter {
- // Sends a greeting
- rpc SayHello (HelloRequest) returns (HelloReply) {}
- }
- // The request message containing the user's name.
- message HelloRequest {
- string name = 1;
- }
- // The response message containing the greetings
- message HelloReply {
- string message = 1;
- }
main.go
- package main
- import (
- "context"
- "fmt"
- "grpc-hello/proto"
- "log"
- "net"
- "google.golang.org/grpc"
- "google.golang.org/grpc/reflection"
- )
- func main() {
- lis, err := net.Listen("tcp", ":50051")
- if err != nil {
- log.Fatalf("failed to listen: %v", err)
- }
- server := grpc.NewServer()
- // 注冊 grpcurl 所需的 reflection 服務
- reflection.Register(server)
- // 注冊業(yè)務服務
- proto.RegisterGreeterServer(server, &greeter{})
- fmt.Println("grpc server start ...")
- if err := server.Serve(lis); err != nil {
- log.Fatalf("failed to serve: %v", err)
- }
- }
- type greeter struct {
- }
- func (*greeter) SayHello(ctx context.Context, req *proto.HelloRequest) (*proto.HelloReply, error) {
- fmt.Println(req)
- reply := &proto.HelloReply{Message: "hello"}
- return reply, nil
- }
運行服務:
- go run main.go
- server start ...
grpcurl 安裝
這里我介紹三種方式:
Mac
- brew install grpcurl
Docker
- # Download image
- docker pull fullstorydev/grpcurl:latest
- # Run the tool
- docker run fullstorydev/grpcurl api.grpc.me:443 list
go tool
如果有 Go 環(huán)境的話,可以通過 go tool 來安裝:
- go install github.com/fullstorydev/grpcurl/cmd/grpcurl@latest
grpcurl 使用
查看服務列表:
- grpcurl -plaintext 127.0.0.1:50051 list
輸出:
- grpc.reflection.v1alpha.ServerReflection
- proto.Greeter
查看某個服務的方法列表:
- grpcurl -plaintext 127.0.0.1:50051 list proto.Greeter
輸出:
- proto.Greeter.SayHello
查看方法定義:
- grpcurl -plaintext 127.0.0.1:50051 describe proto.Greeter.SayHello
輸出:
- proto.Greeter.SayHello is a method:
- rpc SayHello ( .proto.HelloRequest ) returns ( .proto.HelloReply );
查看請求參數(shù):
- grpcurl -plaintext 127.0.0.1:50051 describe proto.HelloRequest
輸出:
- proto.HelloRequest is a message:
- message HelloRequest {
- string name = 1;
- }
請求服務:
- grpcurl -d '{"name": "zhangsan"}' -plaintext 127.0.0.1:50051 proto.Greeter.SayHello
輸出:
- {
- "message": "hello"
- }
可能遇到的錯誤
可能會遇到兩個報錯:
1、gRPC Server 未啟用 TLS:
報錯信息:
- Failed to dial target host "127.0.0.1:50051": tls: first record does not look like a TLS handshake
解決:
請求時增加參數(shù):-plaintext,參考上面的命令。
2、參數(shù)格式錯誤:
報錯信息:
- Error invoking method "greet.Greeter/SayHello": error getting request data: invalid character 'n' looking for beginning of object key string
解決:
-d 后面參數(shù)為 json 格式,并且需要使用 '' 包裹起來。
總結(jié):
用這個工具做一些簡單的測試還是相當方便的,上手也簡單。只要掌握文中提到的幾條命令,基本可以涵蓋大部分的測試需求了。
擴展閱讀:
https://appimage.github.io/BloomRPC/
https://github.com/fullstorydev/grpcurl
文章中的腦圖和源碼都上傳到了 GitHub,有需要的同學可自行下載。
地址: https://github.com/yongxinz/gopher/tree/main/blog
本文轉(zhuǎn)載自微信公眾號「AlwaysBeta」,可以通過以下二維碼關注。轉(zhuǎn)載本文請聯(lián)系AlwaysBeta公眾號。