使用 grpcurl 通过命令行访问 gRPC 服务

简介: 使用 grpcurl 通过命令行访问 gRPC 服务

原文链接:使用 grpcurl 通过命令行访问 gRPC 服务


一般情况下测试 gRPC 服务,都是通过客户端来直接请求服务端。如果客户端还没准备好的话,也可以使用 BloomRPC 这样的 GUI 客户端。


如果环境不支持安装这种 GUI 客户端的话,那么有没有一种工具,类似于 curl 这样的,直接通过终端,在命令行发起请求呢?


答案肯定是有的,就是本文要介绍的 grpcurl


gRPC Server


首先来写一个简单的 gRPC Server:


helloworld.proto:


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)
  // 注册业务服务
  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 环境的话,可以通过 go tool 来安装:


go install github.com/fullstorydev/grpcurl/cmd/grpcurl@latest
复制代码


grpcurl 使用


在使用 grpcurl 时,需要通过 -cert-key 参数设置公钥和私钥文件,表示链接启用了 TLS 协议的服务。


对于没有启用 TLS 协议的 gRPC 服务,通过 -plaintext 参数忽略 TLS 证书的验证过程。


如果是 Unix Socket 协议,则需要指定 -unix 参数。


查看服务列表:


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 );
复制代码


查看请求参数:


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"
}
复制代码


-d 参数后面也可以跟 @,表示从标准输入读取 json 参数,一般用于输入比较复杂的 json 数据,也可以用于测试流方法。


grpcurl -d @ -plaintext 127.0.0.1:50051 proto.Greeter.SayHello
复制代码


可能遇到的错误


可能会遇到三个报错:


1、gRPC Server 未启用 TLS:


报错信息:


Failed to dial target host "127.0.0.1:50051": tls: first record does not look like a TLS handshake
复制代码


解决:


请求时增加参数:-plaintext,参考上面的命令。


2、服务没有启动 reflection 反射服务


报错信息:


Failed to list services: server does not support the reflection API
复制代码


解决:


这行代码是关键,一定要包含:


// 注册 grpcurl 所需的 reflection 服务
reflection.Register(server)
复制代码


3、参数格式错误:


报错信息:


Error invoking method "greet.Greeter/SayHello": error getting request data: invalid character 'n' looking for beginning of object key string
复制代码


解决:


-d 后面参数为 json 格式,并且需要使用 '' 包裹起来。


总结:


用这个工具做一些简单的测试还是相当方便的,上手也简单。只要掌握文中提到的几条命令,基本可以涵盖大部分的测试需求了。



扩展阅读:


  1. appimage.github.io/BloomRPC/
  2. github.com/fullstoryde…


文章中的脑图和源码都上传到了 GitHub,有需要的同学可自行下载。


地址:github.com/yongxinz/go…



目录
相关文章
|
存储 监控 Kubernetes
k8s诊断之记一次pod oom的异常shmem输出
客户反馈java设置xms,xmx参数固定8G内存,而pod的limit则为16G, 三番五次出现了pod oom的情况,且oom的时候他的业务进程输出也是8g, 同时promethus的监控对应pod的working_set_memory也是8个多g, 剩下的几个g的内存到底去哪里了呢?
4456 1
k8s诊断之记一次pod oom的异常shmem输出
go 换源 国内源
go 换源 国内源
1416 0
|
传感器 监控 Java
如何正确理解 CPU 使用率和平均负载的关系?看完你就知道了
CPU(Central Processing Unit)是计算机系统的运算和控制核心,是信息处理、程序运行的最终执行单元,相当于系统的“大脑”。
4123 0
如何正确理解 CPU 使用率和平均负载的关系?看完你就知道了
|
缓存 Linux 开发工具
CentOS 7- 配置阿里镜像源
阿里镜像官方地址http://mirrors.aliyun.com/ 1、点击官方提供的相应系统的帮助 :2、查看不同版本的系统操作: 下载源1、安装wget yum install -y wget2、下载CentOS 7的repo文件wget -O /etc/yum.
261154 0
|
存储 Kubernetes 调度
k8s常见的排错指南Node,svc,Pod等以及K8s网络不通问题
k8s常见的排错指南Node,svc,Pod等以及K8s网络不通问题
5089 1
|
8月前
|
Kubernetes 安全 虚拟化
VMware Fusion 13.6.3 发布下载,现在完全免费无论个人还是商业用途
VMware Fusion 13.6.3 发布下载,现在完全免费无论个人还是商业用途
16477 10
VMware Fusion 13.6.3 发布下载,现在完全免费无论个人还是商业用途
|
搜索推荐 应用服务中间件 nginx
docker与containerd镜像获取及导出导入的区别与注意事项(报错信息:ctr: content digest sha256........ac47: not found)
docker与containerd镜像获取及导出导入的区别与注意事项(报错信息:ctr: content digest sha256........ac47: not found)
948 2
|
存储 关系型数据库 MySQL
PostgreSQL与MySQL优劣势比较浅谈
PostgreSQL与MySQL优劣势比较浅谈
2136 0
|
域名解析 网络协议 应用服务中间件
nginx-ingress通过ipv6暴露服务,并在nginx ingress日志中记录客户端真实ipv6的ip地址
本文主要通过阿里云提供的clb和nlb来实现,建议是提前创建好双栈的vpc和vsw(使用clb可以不用双栈vpc和vsw)
1213 1
|
存储 缓存 JavaScript
Flutter笔记:关于WebView插件的用法(上)
Flutter笔记:关于WebView插件的用法(上)
4070 5