gRPC in Go

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

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

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

查看所有标签

猜你喜欢:

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

四步创业法

四步创业法

[美] Steven Gary Blank / 七印部落 / 华中科技大学出版社 / 2012-8-1 / 48.00

《四步创业法》获李开复推荐,是精益创业理论的奠基之作。作者Steven Gary Blank博士是硅谷资深企业家,他一共创办了八家企业,并担任多家硅谷公司的董事和创业顾问。本书总结作者25年创业经验,提出全新的客户发展方法 (诣在弥补传统产品开发方法的缺陷) ,掀起了硅谷近年精益创业 的浪潮。七印部落正在翻译作者的博客和授课视频,欢迎访问微博:http://weibo.com/7seals ......一起来看看 《四步创业法》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具