gRPC in Go

栏目: 服务器 · 发布时间: 6年前

内容简介:本文将向你介绍 gRPC 和 protocol buffers。代码示例:在 gRPC 中,客户端可以直接调用其他机器上的提供方法,并且客户端感觉就像是本地调用一样,这使得创建分布式应用程序和服务更加轻松。

本文将向你介绍 gRPC 和 protocol buffers。代码示例: demo

简介

在 gRPC 中,客户端可以直接调用其他机器上的提供方法,并且客户端感觉就像是本地调用一样,这使得创建分布式应用程序和服务更加轻松。

gRPC

在服务器端,服务器实现此接口并运行 gRPC Server 来处理客户端调用。在客户端,客户端有一个 Stub(有些地方称为 Client),它提供与服务器相同的方法。

gRPC 客户端和服务器可以在各种环境中相互运行和通信,并且可以使用任何 gRPC 支持的语言编写。

安装

gRPC 需要 Go 版本在 1.6 以上。

然后,安装 gRPC 和 Protocol Buffers v3。

$ go get -u google.golang.org/grpc
$ brew install protobuf # on macOS, others can find from https://github.com/protocolbuffers/protobuf/releases
$ go get -u github.com/golang/protobuf/protoc-gen-go

使用 protocol buffers

接下来的学习请先阅读 protocol buffers 再继续。

我们可以直接在 .proto 文件中定义服务,请看下面的示例:

message HelloRequest {
  string Data = 1;
}

message HelloResponse {
  string Data = 1;
}

service Hello {
  rpc Hello (HelloRequest) returns (HelloResponse) {};
}

然后使用 grpc 插件通过命令 protoc --proto_path=IMPORT_PATH --go_out=plugins=grpc:DST_DIR path/to/file.proto 生成相关的代码。

服务定义

gRPC 允许定义四种服务方法:

proto rpc SayHello(HelloRequest) returns (HelloResponse){ } 
proto rpc LotsOfReplies(HelloRequest) returns (stream HelloResponse){ } 
proto rpc LotsOfGreetings(stream HelloRequest) returns (HelloResponse) { } 
proto rpc BidiHello(stream HelloRequest) returns (stream HelloResponse){ } 

流式的处理方法:

  • 服务器流式 RPC
func (s *routeGuideServer) ListFeatures(rect *pb.Rectangle, stream pb.RouteGuide_ListFeaturesServer) error {
  	for ... {
  		// ...

  		if err := stream.Send(feature); err != nil {
  			return err
  		}

  		// ...
  	}
  	return nil
  }
  • 客户端流式 RPC
func (s *routeGuideServer) RecordRoute(stream pb.RouteGuide_RecordRouteServer) error {
  	for {
  		point, err := stream.Recv()
  		if err == io.EOF {
  			return stream.SendAndClose(&pb.RouteSummary{...})
  		}
  		if err != nil {
  			return err
  		}

  		// ...
  	}
  }
  • 双向流式 RPC
func (s *routeGuideServer) RouteChat(stream pb.RouteGuide_RouteChatServer) error {
  	for {
  		in, err := stream.Recv()
  		if err == io.EOF {
  			return nil
  		}
  		if err != nil {
  			return err
  		}

  		// ...

  		for ... {
  			if err := stream.Send(note); err != nil {
  				return err
  			}
  		}
  	}
  }

身份验证

gRPC 内置了两种身份验证机制:

  • SSL/TLS
  • 使用 Google 进行基于令牌的身份验证

代码示例

1.没有加密和认证的情况

Client:

conn, _ := grpc.Dial("localhost:50051", grpc.WithInsecure())
// error handling omitted
client := pb.NewGreeterClient(conn)
// ...

Server:

s := grpc.NewServer()
lis, _ := net.Listen("tcp", "localhost:50051")
// error handling omitted
s.Serve(lis)

2.带有 SSL/TLS 的情况

Client:

creds, _ := credentials.NewClientTLSFromFile(certFile, "")
conn, _ := grpc.Dial("localhost:50051", grpc.WithTransportCredentials(creds))
// error handling omitted
client := pb.NewGreeterClient(conn)
// ...

Server:

creds, _ := credentials.NewServerTLSFromFile(certFile, keyFile)
s := grpc.NewServer(grpc.Creds(creds))
lis, _ := net.Listen("tcp", "localhost:50051")
// error handling omitted
s.Serve(lis)

3.使用 Google 验证

pool, _ := x509.SystemCertPool()
// error handling omitted
creds := credentials.NewClientTLSFromCert(pool, "")
perRPC, _ := oauth.NewServiceAccountFromFile("service-account.json", scope)
conn, _ := grpc.Dial(
	"greeter.googleapis.com",
	grpc.WithTransportCredentials(creds),
	grpc.WithPerRPCCredentials(perRPC),
)
// error handling omitted
client := pb.NewGreeterClient(conn)
// ...

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

爆发

爆发

[美] 艾伯特-拉斯洛·巴拉巴西 / 马慧 / 中国人民大学出版社 / 2012-6 / 59.90元

1. 本书是一本超越《黑天鹅》的惊世之作。如果说塔勒布认为人类行为是随机的,都是小概率事件,是不可以预测的;那么全球复杂网络权威Barabasi则认为,人类行为93%是可以预测的。 2. Barabasi的研究是在人类生活数字化的大数据时代基础上进行的,移动电话、网络以及电子邮件使人类 行为变得更加容易量化,将我们的社会变成了一个巨大的数据库。他认为,人类正处在一个聚合点上,在这里数据、科学......一起来看看 《爆发》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码

html转js在线工具
html转js在线工具

html转js在线工具