博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Golang gRPC实践 连载一 gRPC介绍与安装
阅读量:6328 次
发布时间:2019-06-22

本文共 2407 字,大约阅读时间需要 8 分钟。

hot3.png

 是一个高性能、开源、通用的RPC框架,由Google推出,基于协议标准设计开发,默认采用数据序列化协议,支持多种开发语言。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支持的不同语言实现。

bVHeg5?w=968&h=621

grpc库与protobuf

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

准备工作

  • Linux系统安装 

  • MAC OS X系统安装 

安装

脚本安装

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

或者直接使用brew安装:

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

安装结果:

/usr/local/binprotocgrpc_cpp_plugingrpc_node_plugingrpc_python_plugingrpc_csharp_plugingrpc_objective_c_plugingrpc_ruby_plugin

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

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中,这样在编译.proto文件时protocol编译器才能找到插件。

grpc-go

# 如果需要翻墙自己解决吧go get -u google.golang.org/grpc

编译器使用

使用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 参数:指定import路径,可以指定多个-I参数,编译时按顺序查找,不指定时默认查找当前目录

  • --go_out :golang编译支持,支持以下参数

    • plugins=plugin1+plugin2 - 指定插件,目前只支持grpc,即:plugins=grpc

    • M 参数 - 指定导入的.proto文件路径编译后对应的golang包名(不指定本参数默认就是.proto文件中import语句的路径)

    • import_prefix=xxx - 为所有import路径添加前缀,主要用于编译子目录内的多个proto文件,这个参数按理说很有用,尤其适用替代一些情况时的M参数,但是实际使用时有个蛋疼的问题导致并不能达到我们预想的效果,自己尝试看看吧

    • import_path=foo/bar - 用于指定未声明packagego_package的文件的包名,最右面的斜线前的字符会被忽略

    • 末尾 :编译文件路径 .proto文件路径(支持通配符)

完整示例:

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

参考

本系列示例代码

相关文档:

相关项目

转载于:https://my.oschina.net/ifraincoat/blog/879540

你可能感兴趣的文章
"途牛+巨杉" 诠释在线旅游与大数据结合
查看>>
保护物联网的数据隐私和在线安全的7种方式
查看>>
混合云扛起云存储领军大旗
查看>>
5G空口存疑 革新还是4G演进?
查看>>
We wear culture:Google 艺术与文化项目带你探秘穿在身上的文化
查看>>
5G:非正交多址接入技术(NOMA)
查看>>
数据中心规划设计中值得注意的八个问题
查看>>
HPE谢少毅:更敏捷的企业服务,做有生命力的落地实践
查看>>
机器学习数据管理初创公司SafeGraph融资1600万美元
查看>>
AngularJS中使用HTML5摄像头拍照
查看>>
前端开发js运算符单竖杠“|”的用法和作用及js数据处理
查看>>
5G时代渐行渐近 移动承载网络面临新挑战
查看>>
从科幻灵感开始的一场数据存储基础设施实验之旅
查看>>
5G前夜 运营商如何实现网络创新?
查看>>
用Async函数简化异步代码
查看>>
企业上云需跨越哪些“雷区”?
查看>>
数据中心网络流量精细运维
查看>>
以网络安全为例的大数据可视化设计
查看>>
传说中的“智能袖套”:把柔性手机戴在手腕上
查看>>
澳大利亚铁路网络漏洞多多 极易遭攻击
查看>>