快速开始

概述

本文将介绍如何快速使用 gRPC client 连接 rpc。

示例

准备工作

事先我们执行如下执行生成一个 proto 文件及其 pb 文件。

  1. # 创建 demo 服务目录
  2. $ mkdir demo && cd demo
  3. # go mod 初始化
  4. $ go mod init demo
  5. # 生成 greet.proto 文件
  6. $ goctl rpc -o greet.proto
  7. # 生 pb.go 文件
  8. $ protoc greet.proto --go_out=. --go-grpc_out=.
  9. # 创建 client 目录
  10. $ mkdir client && cd client
  11. # 新增配置文件
  12. $ mkdir etc && cd etc
  13. $ touch greet-client.yaml
  14. # 新增 client.go 文件
  15. $ touch client.go

参考配置及内容如下

  • etc/greet-client.yaml
  • client.go
  1. Target: 127.0.0.1:8080
  1. func main() {
  2. var clientConf zrpc.RpcClientConf
  3. conf.MustLoad("etc/client.yaml", &clientConf)
  4. conn := zrpc.MustNewClient(clientConf)
  5. resp, err := client.Ping(context.Background(), &greet.Request{})
  6. if err != nil {
  7. log.Fatal(err)
  8. return
  9. }
  10. log.Println(resp)
  11. }
快速开始 - 图1小技巧

如果你也觉得这样写代码很麻烦,不妨试试 goctl 脚手架代码生成,详情可参考 goctl rpc

更多 gRPC 连接(服务注册、服务发现、集群直连、中间件使用等)可参考 rpc 服务连接

参考文献