首页 » PHP教程 » phprpc传输技巧_Java高级架构师RPC基本事理

phprpc传输技巧_Java高级架构师RPC基本事理

duote123 2024-12-07 0

扫一扫用手机浏览

文章目录 [+]

1、开拓步骤

RPC(Remote Procedure Call),远程过程调用,大部分的RPC框架都遵照如下三个开拓步骤:

phprpc传输技巧_Java高级架构师RPC基本事理

1. 定义一个接口解释文件:描述了工具(构造体)、工具成员、接口方法等一系列信息;

phprpc传输技巧_Java高级架构师RPC基本事理
(图片来自网络侵删)

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

私信头条号,发送:“资料”,获取更多“秘制” 佳构学习资料

如有收成,请帮忙转发,您的鼓励是作者最大的动力,感激!

标签:

相关文章

介绍白点控制之路,从原理到方法

白点,作为生活中常见的现象,无处不在。对于如何控制白点,许多人却感到困惑。本文将从原理出发,探讨白点的控制方法,并结合实际案例,为...

PHP教程 2025-01-03 阅读1 评论0

介绍直播王者,如何开启你的电竞直播之旅

随着电竞产业的蓬勃发展,越来越多的年轻人投身于电竞直播行业。王者荣耀作为一款备受欢迎的MOBA手游,吸引了大量玩家和观众。如何开启...

PHP教程 2025-01-03 阅读1 评论0