RPC调用链通信方法

RPC调用链通信方法,第1张

RPC调用链通信方法

RPC调用链可以将远程过程调用变成一个有效的堆栈。

当我们编写应用程序时,我们中的许多人认为REST是服务间通信的一个通用标准。然而,还有许多其他形式的通信,RPC就是其中之一。值得注意的是,通信方式的选择取决于许多因素,如业务需求、遗留代码、技术和预算,更不用说你选择的架构模式。

在分布式计算中很受欢迎,RPC(远程过程调用)是一个程序,其中计算机程序在不同的计算机(服务器)中执行,而程序(代码)抽象出客户端和服务器之间的连接。

你们中的许多人可以在互联网上了解RPC,但我发现很难找到关于 "RPC链"的信息。我甚至不知道它的存在,直到最近,我在微软研究院读到一篇有趣的论文。

1. 引言:RPC与RPC链的关系

RPC链解决了与标准RPC有关的性能和效率问题,一个单一的任务可能涉及到对不同站点的几个客户服务器调用。如果你看下图,你可以立即注意到其中的差别。

RPC链允许客户端连续调用多个服务器(A-B-E-F-C-D-A),而无需每次都让客户端参与。

2. 主要机制

作为RPC模型中以服务函数(远程方法)形式提供的服务器服务,它们可以在一个函数链中进行逻辑排序,指定执行的下一个服务函数(可能在不同的服务器上)。正如作者所说,它们可以是C#或Java方法(存储并因此从远程存储库检索到服务),但它们不能引用非本地变量,因为它们需要独立编译。

3. 链条断裂:检测和恢复

任何服务器都可能在RPC链执行过程中崩溃。它是由一个简单的机制检测出来的,这个机制被称为链心跳,链会定期向创建它的客户端发送一个活着的消息,并带有其独特的链标识符。

如果检测到链条断裂,客户端会重新传输请求,然后,由于每个服务器的缓存结果,这个过程会从链条断裂的主机继续进行。

结语

RPC链将RPC调用组合成一条链,从而可以减少使用复杂嵌套服务调用的应用程序中的网络跳数(从而减少端到端的延迟)和带宽,因为客户端不会收到不必要的数据。关于RPC链的更多详细信息,请阅读原始论文。

参考:

RPC chainsRPC Chains: Efficient Client-Server Communication in Geodistributed Systems一种高效通信机制-RPC调用链 https://www.rayylee.xyz/2022/01/16/rpc_call_chains_20220116/

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/zaji/5707958.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存