RPC调用链通信方法

Posted rayylee

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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调用链通信方法的主要内容,如果未能解决你的问题,请参考以下文章

区块链 | 智能合约Ethereum源代码- 以太坊RPC通信实例和原理代码分析(上)

手写RPC,深入底层理解整个RPC通信

[go微服务-16] Go RPC 实现服务间通信

架构修炼之道-RPC通信

基于Zipkin的Thrift服务RPC调用链跟踪

技术周刊|浅谈区块链的底层架构之RPC及Mempool模块