远程过程调用协议RPC(Remote Procedure Call Protocol)

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

首先,要解决通讯的问题,主要是通过在客户端和服务器之间建立TCP连接,远程过程调用的所有交换的数据都在这个连接里传输。连接可以是按需连接,调用结束后就断掉,也可以是长连接,多个远程过程调用共享同一个连接。第二,要解决寻址的问题,也就是说,A服务器上的应用怎么告诉底层的RPC框架,如何连接到B服务器(如主机或IP地址)以及特定的端口,方法的名称名称是什么,这样才能完成调用。比如基于Web服务协议栈的RPC,就要提供一个endpoint URI,或者是从UDDI服务上查找。如果是RMI调用的话,还需要一个RMI Registry来注册服务的地址。

第三,当A服务器上的应用发起远程过程调用时,方法的参数需要通过底层的网络协议如TCP传递到B服务器,由于网络协议是基于二进制的,内存中的参数的值要序列化成二进制的形式,也就是序列化(Serialize)或编组(marshal),通过寻址和传输将序列化的二进制发送给B服务器。

第四,B服务器收到请求后,需要对参数进行反序列化(序列化的逆操作),恢复为内存中的表达方式,然后找到对应的方法(寻址的一部分)进行本地调用,然后得到返回值。

第五,返回值还要发送回服务器A上的应用,也要经过序列化的方式发送,服务器A接到后,再反序列化,恢复为内存中的表达方式,交给A服务器上的应用

最新文章

  1. 【转】【C#】判断两个文件是否相同
  2. footer居底
  3. Unity3d 动态批处理的问题
  4. Standalone HBase
  5. java中服务器启动时,执行定时任务
  6. leetcode First Missing Positive hashset简单应用
  7. JS 实现 startWith endWith函数
  8. php的一些小笔记--数组
  9. Jquery读取URL参数
  10. C# Redis学习系列一:Redis的认识、下载、安装、使用
  11. 关于RDLC报表打印预览界面显示页码问号的问题
  12. [2]十道算法题【Java实现】
  13. Dubbo优雅关机原理
  14. MooFest POJ1990
  15. PHP之数组函数
  16. [z]oracle 创建job
  17. code first 添加外键时,与原有的数据冲突ALTER TABLE 语句与 FOREIGN KEY 约束"FK_XXXXX"冲突
  18. Linux高级文件系统管理(8)
  19. e739. 创建一个标签组件
  20. 安装ubuntu16.04系统后没有无线网络选项的解决方法

热门文章

  1. redis以服务模式开机启动
  2. Swift 结构体struct
  3. 十、React 父组件传来值的类型控制propTypes、父组件如果不传值defaultProps
  4. Python MySQL 入门
  5. DRF教程10-关系字段
  6. jmeter --- 组件
  7. Adobe Photoshop CC2014 for MAC 详细破解步骤
  8. POJ 2481:Cows 树状数组
  9. MFC OCX 控件事件的添加和处理
  10. 关于低成本Sub-1Ghz无线射频方案首选:CMT2110A