您的位置:首页 > 其它

RPC原理详解

2016-06-30 11:23 190 查看
RPC 的主要功能目标是让构建分布式计算(应用)更容易,在提供强大的远程调用能力时不损失本地调用的语义简洁性。 为实现该目标,RPC 框架需提供一种透明调用机制让使用者不必显式的区分本地调用和远程调用。 下面我们将具体细化 stub 结构的实现。

RPC 调用分类

RPC 调用分以下两种:

同步调用

客户方等待调用执行完成并返回结果。

异步调用

客户方调用后不用等待执行结果返回,但依然可以通过回调通知等方式获取返回结果。 若客户方不关心调用返回结果,则变成单向异步调用,单向调用不用返回结果。

异步和同步的区分在于是否等待服务端执行完成并返回结果。

RPC 结构拆解

如下图所示。

RPC原理详解

RPC 服务方通过 RpcServer 去导出(export)远程接口方法,而客户方通过 RpcClient 去引入(import)远程接口方法。 客户方像调用本地方法一样去调用远程接口方法,RPC 框架提供接口的代理实现,实际的调用将委托给代理 RpcProxy 。 代理封装调用信息并将调用转交给 RpcInvoker 去实际执行。 在客户端的 RpcInvoker 通过连接器 RpcConnector 去维持与服务端的通道 RpcChannel, 并使用 RpcProtocol 执行协议编码(encode)并将编码后的请求消息通过通道发送给服务方。

RPC 服务端接收器 RpcAcceptor 接收客户端的调用请求,同样使用 RpcProtocol 执行协议解码(decode)。 解码后的调用信息传递给 RpcProcessor 去控制处理调用过程,最后再委托调用给 RpcInvoker 去实际执行并返回调用结果。

RPC 组件职责

上面我们进一步拆解了 RPC 实现结构的各个组件组成部分,下面我们详细说明下每个组件的职责划分。

RpcServer

负责导出(export)远程接口

RpcClient

负责导入(import)远程接口的代理实现

RpcProxy

远程接口的代理实现

RpcInvoker

客户方实现:负责编码调用信息和发送调用请求到服务方并等待调用结果返回

服务方实现:负责调用服务端接口的具体实现并返回调用结果

RpcProtocol

负责协议编/解码

RpcConnector

负责维持客户方和服务方的连接通道和发送数据到服务方

RpcAcceptor

负责接收客户方请求并返回请求结果

RpcProcessor

负责在服务方控制调用过程,包括管理调用线程池、超时时间等

RpcChannel

数据传输通道
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  rpc