在golang中如何使用gRPC和Protocol buffers

定义

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中的一个合约。它接受一个消息,返回另一个消息。
实现一个服务的步骤如下:

  1. 创建服务和消息的protocol buffer文件;
  2. 编译protocol buffer文件;
  3. 使用产生的golang文件来创建一个gRPC服务器;
  4. 创建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) {
   }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值