RPC协议
英文原义:Remote Procedure Call Protocol
中文释义:(RFC-1831)远程调用协议 ,最初由RFC-1050定义。
注解:一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。
RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。
RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供程序就是一个服务器。首先,调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。在服务器端,进程保持睡眠状态直到调用信息的到达为止。当一个调用信息到达,服务器获得进程参数,计算结果,发送答复信息,然后等待下一个调用信息,最后,客户端调用过程接收答复信息,获得进程结果,然后调用执行继续进行。
目前,有多种RPC模式和执行。最初由Sun公司提出。IETF ONC宪章重新修订了Sun版本,使得ONC RPC协议成为IETF标准协议。现在使用最普遍的模式和执行是开放式软件基础的分布式计算环境(DCE)。
远程过程调用(RPC)信息协议由两个不同结构组成:调用信息和答复信息。
RPC 调用信息:每条远程过程调用信息包括以下无符号整数字段,以独立识别远程过程:
程序号(Program number)
程序版本号(Program version number)
过程号(Procedure number)
RPC 调用信息主体形式如下:
struct call_body {
unsigned int rpcvers;
unsigned int prog;
unsigned int vers;
unsigned int proc;
opaque_auth cred;
opaque_auth verf;
1 parameter
2 parameter . . .
};
RPC 答复信息:RPC 协议的答复信息的改变取决于网络服务器对调用信息是接收还是拒绝。答复信息请求包括区别以下情形的各种信息:
RPC 成功执行调用信息。.
RPC 的远程实现不是协议第二版,返回 RPC 支持的最低和最高版本号。
在远程系统中,远程程序不可用。
远程程序不支持被请求的版本号。返回远程程序所支持的最低和最高版本号。
请求的过程号不存在。通常是呼叫方协议或程序差错。
RPC答复信息形式如下:
enum reply_stat stat {
MSG_ACCEPTED = 0,
MSG_DENIED = 1
};
分享到:
相关推荐
netty的rpc协议的简单实现
RPC协议解析
DCERPC协议pcap数据包下载,支持抓包软件(如:wireshark)打开并学习DCERPC协议报文解析。需要其他协议,请查看我发布的其他资源。
xml-rpc 是一套规范及其一系列的实现,允许运行在不同操作系统... 这种远程过程调用使用http作为传输协议,xml作为传送信息的编码格式。Xml-Rpc的定义尽可能的保持了简单,但同时能够传送、处理、返回复杂的数据结构。
7. RPC协议要求 4 7.1 RPC程序和过程 4 7.2 鉴定 5 7.3 程序号委派 5 7.4 RPC协议的其它使用 6 8. RPC信息协议 6 9. 鉴定协议 9 9.1 空鉴定 9 9.2 Unix鉴定 9 9.3 DES 鉴定 10 10. 记录记号标准 13 11. RPC语言 13 ...
传智播客吴超老师RPC小例子
浅谈微服务的RPC协议
XML-RPC的全称是XML Remote Procedure Call,即XML远程方法调用。 它是一套允许运行在不同操作系统、不同环境的程序实现基于Internet过程调用的规范和一系列的实现。
JSON-RPC协议的C语言版与Python语言版,源代码及示例
protogen java和C#rpc协议
Aria2 Tools - 支持RPC协议.zip
JSON-RPC协议分析、扩展及其应用,李德贤,李嵩山,随着web和中间件技术的飞速发展,二者的结合也日趋紧密,从某种程度上说,web就是中间件。Internet已成为web应用的默认平台,而中间件�
[其他类别]xml-rpc协议 2.2_xmlrpc-2.2.zip
delphi与JSP通过xml-rpc协议交换数据的例子
第35讲 二进制类RPC协议:还是叫NBA吧,总说全称多费劲1
一个轻量级PHP开源接口框架,简称π框架(派框架),配套运营管理平台,专注于接口服务开发,支持HTTP/SOAP/RPC协议,拥有自动生成的在线文档、多种开发语言的客户端SDK包以及可重用的扩展类库,可用于快速搭建微服务...
此插件支持在jmeter中以rpc方式对dubbo接口进行调用、rpc方式调用dubbo,解压包后里面有两个文件,一个是支持rpc的插件,另一个赠送idea中对数据库访问的插件 插件名称:jmeter-plugins-dubbo-2.7.7-jar-with-...
RPC(Remote Procedure Call ...RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。
json-rpc是基于json的跨语言远程调用协议,比xml-rpc、webservice等基于文本的协议传输数据格小;相对hessian、java-rpc等二进制协议便于调试、实现、扩展,是非常优秀的一种远程调用协议。
RPC与HTTP区别网络7层协议如图所示.如图-22所示图-22层级关系与对应的协议.如图-23所示图-23区别:1.RPC是传输层协议(4层).而HTTP协议