gRPC详细入门教程,GolangPythonPHP多语言讲解.pdf

gRPC详细入门教程,GolangPythonPHP多语言讲解.pdf

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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

文档评论(0)

A19855058659 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档