- 1、本文档共13页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
gRPC详细⼊门教程,GolangPythonPHP多语⾔讲解
⼀、gRPC是什么?
gRPC,其实就是RPC框架的⼀种,前⾯带了⼀个g,代表是RPC中的⼤哥,龙头⽼⼤的意思,另外g也有global的意思,意思是全球化⽐
较fashion,是⼀个⾼性能、开源和通⽤的 RPC 框架,⾯向服务端和移动端,基于 HTTP/2 设计。
RPC框架是什么?
RPC 框架说⽩了就是让你可以像调⽤本地⽅法⼀样调⽤远程服务提供的⽅法,⽽不需要关⼼底层的通信细节。简单地说就让远程服务调⽤
更加简单、透明。
RPC包含了客户端(Client)和服务端(Server)
常见的RPC框架有
1. gRPC。⾕歌出品
2. Thrift。Apache出品
3. Dubbo。阿⾥出品,也是⼀个微服务框架
gRPC的特性
看的介绍,有以下4点特性:
1. 使⽤Protocal Buffers这个强⼤的结构数据序列化⼯具
2. grpc可以跨语⾔使⽤
3. 安装简单,扩展⽅便 (⽤该框架每秒可达到百万个RPC)
4. 基于HTTP2协议
gRPC使⽤流程
gprc的使⽤流程⼀般是这样的:
1. 定义标准的proto⽂件
2. ⽣成标准代码
3. 服务端使⽤⽣成的代码提供服务
4. 客户端使⽤⽣成的代码调⽤服务
⼆、 Protocol Buffers是什么?
⾕歌开源的⼀种结构数据序列化的⼯具,⽐⽅说JSON、XML也是结构数据序列化的⼯具,不同的是,
1. Protocol Buffers序列化后的数据是不可读的,因为是⼆进制流
2. 使⽤Protocol Buffer需要事先定义数据的格式(.proto 协议⽂件),还原⼀个序列化之后的数据需要使⽤到这个数据格式
3. Protocol Buffer ⽐ XML、JSON快很多,因为是基于⼆进制流,⽐字符串更省带宽,传输速度快
Protocol Buffer语法:查看
下⾯演⽰根据需求开发项⽬,建议⾃⼰运⾏⼀下,加深印象
三、需求 :开发健⾝房服务
定义 了⼀个健⾝房 (Gym),提供⼀个叫健⾝ (Bodybuilding)的远程⽅法
使⽤该服务,需要指定⼈ (Person),⼈有名字 (name)和训练动作 (actions)两个属性。
对应的协议⽂件to⽂件如下
syntax = proto3;
//命名空间
package lightweight;
//健⾝房
service Gym {
rpc BodyBuilding (Person) returns (Reply) {
}
}
//谁在健⾝
message Person {
string name = 1;
repeated string actions = 2;
}
//结果
message Reply {
int32 code = 1;
string msg = 2;
}
四、最佳实践
下⾯以Golang、Python、PHP介绍该grpc的使⽤,代码已经上传到了
最终⽬录结构如下图
Golang
1. 安装protoc
地址:
我是mac,⽤的是这个地址:
解压后放到了可以访问的bin即可
2. 安装protoc-gen-go
protoc依赖该⼯具⽣成代码
go get -u /golang/protobuf/protoc-gen-go
gogoprotobuf的protoc-gen-gofast插件⽣成的⽂件更复杂,性能也更⾼,安装如下
go get /gogo/protobuf/protoc-gen-gofast
3.安装grpc 包
这是要代码⾥需要使⽤的,go get直接安装不了,⼿动克隆
git clone /grpc/grpc-go.git $GOPATH/src//grpc
git clone /golang/net.git $GOPATH/src//x/net
git clone /golang/text.git $GOPATH/src//x/text
git clone /google/go-genproto.git $GOPATH/src//genproto
cd $GOPATH/src/
go install /grpc
4.⽣成代码
#!/usr/bin/env bash
protoDir=../protos
您可能关注的文档
最近下载
- 福建省厦门市2021-2022学年高二上学期期末质量检测数学试题及答案.pdf
- 中华民族共同体概论课件专家版12第十二讲:民族危亡与中华民族意识觉醒(1840-1919).pptx VIP
- 风电项目资料大全(含归档要求、编制指南、规范表格).pdf
- 《企业内部控制应用指引第6 号资金活动》.pdf
- 建筑施工重大事故隐患排查台账(含判定依据).xls
- 小学少先队辅导员学期工作计划.doc
- (完整版)四年级地方课程教学计划.docx VIP
- 如何上好班会课PPT课件.ppt
- 语文大单元教学设计+作业设计:一年级上册四单元跨学科主题活动.pdf VIP
- 六年级上册科学全册精编教案(新改版教科版).docx
文档评论(0)