Golang RPC 之 gRPC

gRPC 简介:

gRPC 是一款高性能、开源的 RPC 框架,产自 Google,基于 ProtoBuf 序列化协议进行开发,支持多种语言(Golang、Python、Java等),本篇只介绍 Golang 的 gRPC 使用。因为 gRPC 对 HTTP/2 协议的支持使其在 Android、IOS 等客户端后端服务的开发领域具有良好的前景。gRPC 提供了一种简单的方法来定义服务,同时客户端可以充分利用 HTTP/2 stream 的特性,从而有助于节省带宽、降低 TCP 的连接次数、节省CPU的使用等。

安装:

  1. gRPC 的安装:

$ go get -u google.golang.org/grpc

  1. 因为 gRPC 是基于 protobuf 实现的接口序列化,所以也要安装 protobuf: 安装及简介教程

实践:

下面我们使用 gRPC 定义一个接口,该接口实现对传入的数据进行大写的格式化处理。

  1. 创建项目 golang Demo 工程:


    Paste_Image.png
  1. client目录下的 main.go 实现了客户端用于发送数据并打印接收到 server 端处理后的数据
  1. server 目录下的 main.go 实现了服务端用于接收客户端发送的数据,并对数据进行大写处理后返回给客户端

  2. example 包用于编写 proto 文件并生成 data 接口

  3. 定义 gRPC 接口:

syntax = "proto3";
package example;
service FormatData {
    rpc DoFormat(Data) returns (Data){}
}
message Data {
    string text = 1;
}
  1. 编译 protobuf:

$ protoc -I=. --go_out=plugins=grpc:. . // 在 example 目录中执行编译,会生成:data.pb.go

  1. 实现 server 端:
package main
import (
    "Demo/example"
    "net"
    "google.golang.org/grpc"
    "google.golang.org/grpc/reflection"
    "golang.org/x/net/context"
    "strings"
    "log"
)
// 定义监听地址
const (
    HOST string = "localhost"
    PORT string = "8080"
)
// 定义接口
type FormatData struct{}
func (fd *FormatData) DoFormat(ctx context.Context, in *example.Data) (out *example.Data, err error) {
    str := in.Text
    out = &example.Data{Text: strings.ToUpper(str)}
    return out, nil
}
// 直接在 main 方法中注册接口
func main() {
    listener, err := net.Listen("tcp", HOST+":"+PORT)
    if err != nil {
        log.Fatalln("faile listen at: " + HOST + ":" + PORT)
    } else {
        log.Println("Demo server is listening at: " + HOST + ":" + PORT)
    }
    rpcServer := grpc.NewServer()
    example.RegisterFormatDataServer(rpcServer, &FormatData{})
    reflection.Register(rpcServer)
    if err = rpcServer.Serve(listener); err != nil {
        log.Fatalln("faile serve at: " + HOST + ":" + PORT)
    }
}
  1. 实现 client 端:
package main
import (
    "google.golang.org/grpc"
    "log"
    "Demo/example"
    "golang.org/x/net/context"
)
// 定义请求地址
const (
    ADDRESS string = "localhost:8080"
)
// main 方法实现对 gRPC 接口的请求
func main() {
    conn, err := grpc.Dial(ADDRESS, grpc.WithInsecure())
    if err != nil {
        log.Fatalln("Can't connect: " + ADDRESS)
    }
    defer conn.Close()
    client := example.NewFormatDataClient(conn)
    resp,err := client.DoFormat(context.Background(), &example.Data{Text:"hello,world!"})
    if err != nil {
        log.Fatalln("Do Format error:" + err.Error())
    }
    log.Println(resp.Text)
}
  1. 执行验证结果:
  1. 先启动 server,之后再执行 client
  1. client 侧控制台如果打印的结果为: HELLO,WORLD! ,证明 gRPC 接口定义成功
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,306评论 19 139
  • 1)简介 gRPC负载平衡的主要实现机制是外部负载平衡,即通过外部负载平衡器来向客户端提供更新后的服务器列表。 g...
    Jay_Guo阅读 14,549评论 6 22
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,016评论 6 342
  • ProtoBuf: 是一套完整的 IDL(接口描述语言),出自Google,基于 C++ 进行的实现,开发人员可以...
    谢烟客阅读 20,256评论 3 16
  • 昨天结束了清华博物馆组织的“文博夏令营”活动。一路行程,感触良多。 这次参观不但了解了藏族的佛教和民族历史,也为藏...
    四月野在成长阅读 871评论 1 2