gRPC介绍与安装

A high performance, open source, general RPC framework that puts mobile and HTTP/2 first. ——gRPC Website

gRPC 是一个高性能、开源、通用的RPC框架,由Google推出,基于HTTP/2协议标准设计开发,默认采用Protocol Buffers数据序列化协议,支持多种开发语言。gRPC提供了一种简单的方法来精确的定义服务,并且为客户端和服务端自动生成可靠的功能库。

主要特性

  • 强大的IDL
    gRPC使用ProtoBuf来定义服务,ProtoBuf是由Google开发的一种数据序列化协议(类似于XML、JSON、hessian)。ProtoBuf能够将数据进行序列化,并广泛应用在数据存储、通信协议等方面。

  • 多语言支持
    gRPC支持多种语言,并能够基于语言自动生成客户端和服务端功能库。目前已提供了C版本grpc、Java版本grpc-java 和 Go版本grpc-go,其它语言的版本正在积极开发中,其中,grpc支持C、C++、Node.js、Python、Ruby、Objective-C、PHP和C#等语言,grpc-java已经支持Android开发。

  • HTTP/2
    gRPC基于HTTP/2标准设计,所以相对于其他RPC框架,gRPC带来了更多强大功能,如双向流、头部压缩、多复用请求等。这些功能给移动设备带来重大益处,如节省带宽、降低TCP链接次数、节省CPU使用和延长电池寿命等。同时,gRPC还能够提高了云端服务和Web应用的性能。gRPC既能够在客户端应用,也能够在服务器端应用,从而以透明的方式实现客户端和服务器端的通信和简化通信系统的构建。

在gRPC客户端可以直接调用不同服务器上的远程程序,使用姿势看起来就像调用本地程序一样,很容易去构建分布式应用和服务。和很多RPC系统一样,服务端负责实现定义好的接口并处理客户端的请求,客户端根据接口描述直接调用需要的服务。客户端和服务端可以分别使用gRPC支持的不同语言实现。

图片描述

grpc库与protobuf

默认需要单独编译安装grpc与protobuf编译器,grpc/homebrew-grpc项目提供了快速安装脚本,可以直接安装grpc、protobuf编译器及其它语言编译需要的插件。go语言插件需要独立安装。

准备工作

安装

脚本安装

curl -fsSL https://goo.gl/getgrpc | bash -s -- --with-plugins

或者直接使用brew安装:

brew tap grpc/grpc
brew install --with-plugins grpc

安装结果:

/usr/local/bin

protoc
grpc_cpp_plugin
grpc_node_plugin
grpc_python_plugin
grpc_csharp_plugin
grpc_objective_c_plugin
grpc_ruby_plugin

这种安装方式会安装gRPc C/C++库和其它支持语言的proto插件和protobuf编译器。如果用不到这些语言,可以只安装protobuf就好了,参考项目:protobuf。java和go支持有独立项目grpc-java和grpc-go。

Golang protobuf插件

项目地址:golang/protobuf

安装:

  • 要求golang版本 > 1.4

  • 使用前要求安装protocol buffer编译器

运行:

go get -u github.com/golang/protobuf/{proto,protoc-gen-go}
protoc-gen-go$GOBIN$GOPATH/bin$PATH

grpc-go

# 如果需要翻墙自己解决吧
go get -u google.golang.org/grpc(需要翻墙)
此处也可以在github.com镜像下载,1)$go get -u github.com/grpc/grpc-go2)(还原目录)将src/github.com/grpc/grpc-go文件夹复制到src/google.golang.org目录下,如果没有此文件夹则新建一个3)将grpc-go文件夹重命名为grpc,至此grpc安装完成
同理:golang.org/x/tools、net、sys、text、time、tools也可以这样下载,在github.com目录为:github.com/golang/目录下

编译器使用

protoc.proto
protoc --proto_path=IMPORT_PATH --cpp_out=DST_DIR --java_out=DST_DIR --python_out=DST_DIR --go_out=DST_DIR --ruby_out=DST_DIR --javanano_out=DST_DIR --objc_out=DST_DIR --csharp_out=DST_DIR path/to/file.proto

这里详细介绍golang的编译姿势:

-I-I--go_outplugins=plugin1+plugin2plugins=grpcM.protoimportimport_prefix=xxximportMimport_path=foo/barpackagego_package:编译文件路径 .proto文件路径(支持通配符)

完整示例:

protoc -I . --go_out=plugins=grpc,Mfoo/bar.proto=bar,import_prefix=foo/,import_path=foo/bar:. ./*.proto