rpc是什么
来源:互联网 发布:淘宝卖家注册 编辑:程序博客网 时间:2024/06/03 16:37
RPC(Remote Procedure Call)——远程过程调用,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。
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服务器上的应用
原文链接(如有侵权请告知!)
阅读全文
0 0
- RPC是什么
- RPC是什么?
- RPC是什么
- rpc是什么
- RPC是什么
- xml rpc是什么
- RFC、RPC是什么?
- Xml RPC是什么
- XML-RPC是什么?
- RPC协议是什么
- RPC是什么?科普一下
- RPC与Netty是什么鬼
- 通俗的来讲RPC是什么?
- rpc是什么?php中流行的rpc框架有哪些。
- 终于搞清楚了JAX-RPC是什么
- RPC是什么?RPC与REST、Socket的区别?php中流行的rpc框架有哪些?
- SOAP、XML-RPC 以及 REST 之间的区别是什么?
- 中间件 rpc是什么?php中流行的中间件rpc框架有哪些
- 线索二叉树
- JavaScript--彻底理解js中this的指向
- 1274成绩转换
- 【bzoj3333】排队计划 (线段树)
- if测试和语法规则
- rpc是什么
- String和StringBuffer
- 1.研究 sscanf sprintf 2.研究 fread fwrite
- 1284字符串正反连接
- js基础决定你的上升高度
- 详解Harris角点检测及代码实现
- SSM(7)信息单&多删除
- Docker Compose
- Linux —— apt-get命令及端口查看命令