分享
  1. 首页
  2. 文章

快速开始使用grpc(golang版)

你家旭哥 · · 18626 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

开始前准备

安装gprc

go get -u google.golang.org/grpc

安装protocol buffers

protoc编译器这个用于生成gRPC服务代码的。
下载解压后放入PATH路径,供后续使用。接下来安装protoc的go语言的插件go get -u github.com/golang/protobuf/protoc-gen-go

注意:这边插件也必须要在PATH路径下

栗子 采用$GOPATH/src/google.golang.org/grpc/examples/helloworld的栗子

新建helloworld.proto,这个文件可以供多人使用。

syntax = "proto3"; //语法声明
package helloworld; //包名
// Greeter 微服务
service Greeter {
 // Sends a greeting
 rpc SayHello (HelloRequest) returns (HelloReply) {}
}
// HelloRequest 请求数据格式
message HelloRequest {
 string name = 1;
}
// HelloReply 响应数据格式
message HelloReply {
 string message = 1;
}

生成golang的服务代码
protoc -I helloworld/ helloworld/helloworld.proto --go_out=plugins=grpc:helloworld
这个指令支持*.proto模糊匹配。如果有许多文件可以使用helloworld/*.proto 来作为PROTO_FILES

服务端代码

package main
import (
 "context"
 "log"
 "net"
 "google.golang.org/grpc"
 pb "google.golang.org/grpc/examples/helloworld/helloworld"
 "google.golang.org/grpc/reflection"
)
const (
 port = ":50051"
)
type server struct{} //服务对象
// SayHello 实现服务的接口 在proto中定义的所有服务都是接口
func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
 return &pb.HelloReply{Message: "Hello " + in.Name}, nil
}
func main() {
 lis, err := net.Listen("tcp", port)
 if err != nil {
 log.Fatalf("failed to listen: %v", err)
 }
 s := grpc.NewServer() //起一个服务 
 pb.RegisterGreeterServer(s, &server{})
 // 注册反射服务 这个服务是CLI使用的 跟服务本身没有关系
 reflection.Register(s)
 if err := s.Serve(lis); err != nil {
 log.Fatalf("failed to serve: %v", err)
 }
}

客户端代码

package main
import (
 "context"
 "log"
 "os"
 "time"
 "google.golang.org/grpc"
 pb "google.golang.org/grpc/examples/helloworld/helloworld"
)
const (
 address = "localhost:50051"
 defaultName = "world"
)
func main() {
 //建立链接
 conn, err := grpc.Dial(address, grpc.WithInsecure())
 if err != nil {
 log.Fatalf("did not connect: %v", err)
 }
 defer conn.Close()
 c := pb.NewGreeterClient(conn)
 // Contact the server and print out its response.
 name := defaultName
 if len(os.Args) > 1 {
 name = os.Args[1]
 }
 // 1秒的上下文
 ctx, cancel := context.WithTimeout(context.Background(), time.Second)
 defer cancel()
 r, err := c.SayHello(ctx, &pb.HelloRequest{Name: name})
 if err != nil {
 log.Fatalf("could not greet: %v", err)
 }
 log.Printf("Greeting: %s", r.Message)
}

总结:grpc所构建的服务可以作为微服务使用,供接口或者其他模块使用。


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:你家旭哥

查看原文:快速开始使用grpc(golang版)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
18626 次点击
被以下专栏收入,发现更多相似内容
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏