欢迎光临
我们一直在努力

grpcurl如何通过命令行访问gRPC服务

本篇内容主要讲解“grpcurl如何通过命令行访问gRPC服务”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“grpcurl如何通过命令行访问gRPC服务”吧!

    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 -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"
    }

    可能遇到的错误

    可能会遇到两个报错:

    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、参数格式错误:

    报错信息:

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

    解决:

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

    到此,相信大家对“grpcurl如何通过命令行访问gRPC服务”有了更深的了解,不妨来实际操作一番吧!这里是云搜网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    赞(0)
    【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。