1、开拓步骤
RPC(Remote Procedure Call),远程过程调用,大部分的RPC框架都遵照如下三个开拓步骤:
1. 定义一个接口解释文件:描述了工具(构造体)、工具成员、接口方法等一系列信息;

2. 通过RPC框架所供应的编译器,将接口解释文件编译成详细的措辞文件;
3. 在客户端和做事器端分别引入RPC编译器所天生的文件,即可像调用本地方法一样调用做事端代码;
2、通信过程
1、客户过程以正常办法调用客户桩(client stub,一段代码);
2、客户桩天生一个,然后调用本地操作系统;
3、客户端操作系统将发送给远程操作系统;
4、远程操作系统将交给做事器桩(server stub,一段代码);
5、做事器桩将参数提取出来,然后调用做事器过程;
6、做事器实行哀求的操作,操作完成后将结果返回给做事器桩;
7、做事器桩将结果打包成一个,然后调用本地操作系统;
8、做事器操作系统将含有结果的发送回客户端操作系统;
9、客户端操作系统将交给客户桩;
10、客户桩将结果从从中提取出来,返回给调用它的客户过程;
3、和RESTful API比拟
流量花费。RESTful API 在运用层利用 HTTP 协议,哪怕利用轻型、高效、传输效率高的 JSON 也会花费较大的流量,而 RPC 传输既可以利用 TCP 也可以利用 UDP,而且协议一样平常利用二制度编码,大大降落了数据的大小,减少流量花费。
对接异构第三方做事时,常日利用 HTPP/RESTful 等公有协议,对付内部的做事调用,运用选择性能更高的二进制私有协议
二、thrift架构Thrift是一款由Fackbook开拓的可伸缩、跨措辞的做事开拓框架,该框架已经开源并且加入的Apache项目。Thrift紧张功能是:通过自定义的Interface Definition Language(IDL),可以创建基于RPC的客户端和做事真个做事代码。数据和做事代码的天生是通过Thrift内置的代码天生器来实现的。Thrift 的跨措辞性表示在,它可以天生C++, Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, OCaml , Delphi等措辞的代码,且它们之间可以进行透明的通信。
图中Your Code是用户实现的业务逻辑,接下来的FooService.Client和Foo.write()/read()是thrift根据IDL天生的客户端和做事真个代码,对应于RPC中Client stub和Server stub。TProtocol 用来对数据进行序列化与反序列化,详细方法包括二进制,JSON 或者 Apache Thrift 定义的格式。TTransport 供应数据传输功能,利用 Apache Thrift 可以方便地定义一个做事并选择不同的传输协议。
1、TTransport层
代表thrift的数据传输办法,thrift定义了如下几种常用数据传输办法
TSocket: 壅塞式socket;
TFramedTransport: 以frame为单位进行传输,非壅塞式做事中利用;
TFileTransport: 以文件形式进行传输;
2、TProtocol层
代表thrift客户端和做事端之间传输数据的协议,普通来讲便是客户端和做事端之间传输数据的格式(例如json等),thrift定义了如下几种常见的格式
TBinaryProtocol: 二进制格式;
TCompactProtocol: 压缩格式;
TJSONProtocol: JSON格式;
TSimpleJSONProtocol: 供应只写的JSON协议;
3、thrift IDL文件
thrift IDL不支持无符号的数据类型,由于很多编程措辞中不存在无符号类型,thrift支持一下几种基本的数据类型
byte: 有符号字节i16: 16位有符号整数i32: 32位有符号整数i64: 63位有符号整数double: 64位浮点数string: 字符串此外thrift还支持以下容器类型:
list: 一系列由T类型的数据组成的有序列表,元素可以重复;set: 一系列由T类型的数据组成的无序凑集,元素不可重复;map: 一个字典构造,Key为K类型,Value为V类型,相称于java中的HashMap;thrift容器中元素的类型可以是除了service之外的任何类型,包括exception
thirft支持struct类型,目的便是讲一些数据聚合在一起,方便传输管理,struct定义形式如下:
struct People {1:string name;2:i32 age;3:string gender;}
thrift支持列举类型,定义形式如下:
enum Gender {MALE,FEMALE}
thrift支持自定义非常类型exception,非常定义形式如下:
exception RequestException {1:i32 code;2:string reason;}
thrift定义做事相称于Java中创建接口一样,创建的service经由代码生thrift代码天生工具编译后就会天生客户端和做事真个框架代码,service的定义形式如下:
service HelloWorldService {// service中可以定义多少个做事,相称于Java Interface中定义的方法string doAction(1:string name, 2:i32 age);}
thrift支持给类型定义别名,如下所示:
typedef i32 inttypedef i64 long
thrift也支持常量的定义,利用const关键字:
const i32 MAX_RETRIES_TIME = 10;const string MY_WEBSITE = \"大众http://facebook.com\"大众;
thrift支持命名空间,命名空间相称于Java中的package,紧张用于组织代码,thrift利用关键字namespace定义命名空间,格式是namespace 措辞名 路径,如下示例所示:
namespace java com.test.thrift.demo
私信头条号,发送:“资料”,获取更多“秘制” 佳构学习资料
如有收成,请帮忙转发,您的鼓励是作者最大的动力,感激!