定义
gRPC是一种在两个系统间发送和接受消息的传输机制。传统上这些系统是服务器端和客户端。
一个使用golang实现的,用于传输JSON的RPC,我们叫做JSON RPC;类似的,gRPC被设计用来以protocol buf形式来传输数据。
gRPC使创建服务变得容易和优雅。它提供了一组良好的API用于定义和运行服务。
gRPC的主要优势是它可以支持多种语言。Protocol buffers提供了一个通用的数据结构。这样的组合使得系统和不同的技术栈间可以进行无缝通信。
优势
- gRPC使用HTTP/2这个二进制的协议;
- 在HTTP/2中header是可压缩的,这样的话传输负载会比较小;
- 在一个连接中可以发送多个请求;
- 我们可以使用protocol buffers带来的强类型带来的好处;
- 除了请求、响应这种传统模式外,我可以以流的方式处理请求和响应;
安装
go get google.golang.org/grpc
go get -u github.com/golang/protobuf/protoc-gen-go
使用
一个gRPC中的服务就是RPC中的一个合约。它接受一个消息,返回另一个消息。
实现一个服务的步骤如下:
- 创建服务和消息的protocol buffer文件;
- 编译protocol buffer文件;
- 使用产生的golang文件来创建一个gRPC服务器;
- 创建gRPC客户端,用来与服务器通信;
定义服务和消息
syntax = "proto3";
package protofiles;
message TransactionRequest {
string from = 1;
string to = 2;
float amount = 3;
}
message TransactionResponse {
bool confirm = 1;
}
service MoneyTransaction {
rpc MakeTransaction(TransactionRequest) returns (TransactionResponse) {
}
}