gRPC in Go

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

内容简介:本文将向你介绍 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)
// ...

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

查看所有标签

猜你喜欢:

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

从界面到网络空间

从界面到网络空间

(美)海姆 / 金吾伦/刘钢 / 上海科技教育出版社 / 2000-7 / 16.40元

计算机急剧改变了20世纪的生活。今天,我们凭借遍及全球的计算机网络加速了过去以广播、报纸和电视形式进行的交流。思想风驰电掣般在全球翻飞。仅在角落中潜伏着已完善的虚拟实在。在虚拟实在吕,我们能将自己沉浸于感官模拟,不仅对现实世界,也对假想世界。当我们开始在真实世界与虚拟世界之间转换时,迈克尔·海姆问,我们对实在的感觉如何改变?在〈从界面到网络空间〉中,海姆探讨了这一问题,以及信息时代其他哲学问题。他......一起来看看 《从界面到网络空间》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具