- 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
您可能关注的文档
- 大一新生应该如何准备英语四级.pdf
- 外贸从业资格考试辅导实习报告.pdf
- 35kv输电线路运行维护要求.pdf
- 三年级英语下册第6单元《Unit6Howmany》第2课时教案.pdf
- 1七年级英语上册单词表人教版(新课标)4730.pdf
- 个人职业生涯规划7621.pdf
- 2018陕旅版英语四年级上册Unit2WhatDoTheyHaveontheFarm课课练.pdf
- PEP人教版三年级英语上册第二单元第2课时同步练习(附答案).pdf
- 《学会做人-学会学习》主题班会设计方案.pdf
- 七年级语文练习册上册答案人教版.pdf
- 英语人教PEP版八年级(上册)Unit4+writing+写作.pptx
- 人美版美术四年级(上册)8 笔的世界 课件 (1).pptx
- 人美版美术七年级(上册)龙的制作.pptx
- 英语人教PEP版六年级(上册)Unit 2 第一课时.pptx
- 数学苏教版三年级(上册)3.3 长方形和正方形周长的计算 苏教版(共12张PPT).pptx
- 音乐人教版八年级(上册)青春舞曲 课件2.pptx
- 音乐人教版四年级(上册) 第一单元 音乐知识 附点四分音符|人教版.pptx
- 英语人教PEP版四年级(上册)Unit 6 Part B let's learn 1.pptx
- 道德与法治人教版二年级(上册)课件-3.11大家排好队部编版(共18张PPT).pptx
- 人美版美术七年级(上册)《黄山天下奇》课件1.pptx
文档评论(0)