RPC协议

作者: 天马行空爱做梦 | 来源:发表于2021-09-21 17:28 被阅读0次

RPC协议 个人理解:
RPC(remote procedure call)远程过程调用
解决的问题场景是:

A,B俩服务器,其中A机器上的程序无法和B服务器上的接口互相通信,这个时候就需要用到一种特殊的沟通机制,RPC、 这样子就可以完成,A机器上运行的程序可以调用B机器上的程序。

RPC是指远程过程调用,也就是说两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。

比如说,一个方法可能是这样定义的:
Employee getEmployeeByName(String fullName)
那么:
首先,要解决通讯的问题,主要是通过在客户端和服务器之间建立TCP连接,远程过程调用的所有交换的数据都在这个连接里传输。连接可以是按需连接,调用结束后就断掉,也可以是长连接,多个远程过程调用共享同一个连接。
第二,要解决寻址的问题,也就是说,A服务器上的应用怎么告诉底层的RPC框架,如何连接到B服务器(如主机或IP地址)以及特定的端口,方法的名称名称是什么,这样才能完成调用。比如基于Web服务协议栈的RPC,就要提供一个endpoint URI,或者是从UDDI服务上查找。如果是RMI调用的话,还需要一个RMI Registry来注册服务的地址。
第三,当A服务器上的应用发起远程过程调用时,方法的参数需要通过底层的网络协议如TCP传递到B服务器,由于网络协议是基于二进制的,内存中的参数的值要序列化成二进制的形式,也就是序列化(Serialize)或编组(marshal),通过寻址和传输将序列化的二进制发送给B服务器。
第四,B服务器收到请求后,需要对参数进行反序列化(序列化的逆操作),恢复为内存中的表达方式,然后找到对应的方法(寻址的一部分)进行本地调用,然后得到返回值。
第五,返回值还要发送回服务器A上的应用,也要经过序列化的方式发送,服务器A接到后,再反序列化,恢复为内存中的表达方式,交给A服务器上的应用

相关文章

  • http与rpc

    什么是RPC协议?RPC协议与HTTP协议的区别6,790次阅读什么是RPC协议? RPC是一种远程过程调用的协议...

  • RPC学习笔记-协议

    RPC协议 RPC协议同HTTP协议一样,都是属于应用层的协议,可以通过学习HTTP的协议来理解RPC协议. HT...

  • HTTP与RPC(Thrift)

    什么是RPC 从网络协议来说,Http协议与Rpc同属于应用层, 他们的底层都是tcp协议。 从概念上来说,RPC...

  • 跨语言RPC框架

    跨语言RPC框架 RPC框架 RPC(Remote Procedure Call):是一种计算机通信协议。该协议允...

  • Dubbo

    Dubbo(服务治理框架) RPC 各服务都要实现rpc协议,才能实现服务间的调用 rpc:远程过程调用协议,是一...

  • RPC和HTTP的区别

    RPC调用和HTTP调用 1. 协议 RPC是通常基于TCP/IP协议 HTTP基于HTTP协议 2. 效率 RP...

  • 谈谈 RPC

    RPC(Remote Procedure Call),翻译过来就是远程过程调用 。RPC 协议假定某些传输协议的存...

  • 【深度知识】RPC原理及以太坊RPC的实现

    1.摘要 本文介绍RPC协议的原理和调用流程,同时介绍以太坊RPC的实现机制。 2. 内容 2.1 RPC协议和调...

  • RPC协议

    什么是RPC协议英文原义:Remote Procedure Call Protocol (RFC-1831)远过程...

  • RPC协议

    RPC协议 个人理解:RPC(remote procedure call)远程过程调用解决的问题场景是: A,B俩...

网友评论

      本文标题:RPC协议

      本文链接:https://www.haomeiwen.com/subject/vlfigltx.html