`

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

RPC 
阅读更多

一.RPC 远程过程调用协议

        RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。

        RPC是系统间的一种通信方式,系统间常用的通信方式还有http,webservice,rpc等,一般来讲rpc比http和webservice性能高一些,常见的RPC框架有:Thrift,Finagle,Hessian , dubbo,grpc,json-rpc , CORBA、Java RMI、Web Services、RESTful Web Services等。

        主要包含两个大方面: 

        1.A系统与B系统之间的连接传输(如:socket连接) 

        2.序列化与反序列化

        简单的说,RPC就是从一台机器(客户端)上通过参数传递的方式调用另一台机器(服务器)上的一个函数或方法(可以统称为服务)并得到返回的结果。 

        RPC 会隐藏底层的通讯细节(不需要直接处理Socket通讯或Http通讯) 

        RPC 是一个请求响应模型。客户端发起请求,服务器返回响应(类似于Http的工作方式) 

        RPC 在使用形式上像调用本地函数(或方法)一样去调用远程的函数(或方法)。

 

二.远程过程调用发展历程

        ONC RPC (开放网络计算的远程过程调用),OSF RPC(开放软件基金会的远程过程调用) 

        CORBA(Common Object Request Broker Architecture公共对象请求代理体系结构) 

        DCOM(分布式组件对象模型),COM+ 

        Java RMI 

        .NET Remoting 

        XML-RPC,SOAP,Web Service 

        PHPRPC,Hessian,JSON-RPC 

        Microsoft WCF,WebAPI 

        ZeroC Ice,Thrift,GRPC 

        Hprose

 

文章来源:http://blog.csdn.net/lin6286878/article/details/52514786

分享到:
评论

相关推荐

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

    RPC,即Remote Procedure Call Protocol,远程过程调用协议,是一种在分布式系统中实现客户端与服务器端通信的技术。这种协议允许一个程序(客户端)在不理解底层网络细节的情况下,调用运行在另一台计算机(服务器...

    ZeroC Ice3.7 英文版加注中文书签官方手册.zip

    ZeroC Ice 3.7 手册 ... RPC(Remote Procedure Call Protocol 远程过程调用协议),是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC假定某些传输协议的存在,如TCP或UDP,

    RPC(远程过程调用)

    RPC(Remote Procedure Call)是一种计算机通信协议,它允许程序在分布式环境中的一个系统上执行另一系统上的函数或方法,就像是本地调用一样。这个过程涉及到了客户端、服务器端和服务调用的封装,使得开发者无需...

    远程过程调用协议参照.pdf

    远程过程调用协议(Remote Procedure Call Protocol, RPC)是分布式计算领域的一个重要概念,它允许一台计算机上的程序调用另一台计算机上的程序,而开发者无需了解网络通信的细节。本文档主要参照的RPC协议内容可能...

    remote procedure call using protobuffer

    远程过程调用(RPC,Remote Procedure Call)是一种在分布式系统中实现客户端与服务器间通信的技术。RPC使得客户端能够像调用本地函数一样调用远端服务器上的服务,大大简化了跨网络的服务交互。本主题主要关注使用...

    ZeroC Ice 3.7 手册

    RPC(Remote Procedure Call Protocol 远程过程调用协议),是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC假定某些传输协议的存在,如TCP或UDP,为通讯程序之间携带信息数据;在...

    Ice-3.7.1.rar

     RPC(Remote Procedure Call Protocol 远程过程调用协议),是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC假定某些传输协议的存在,如TCP或UDP,为通讯程序之间携带信息数据;...

    rpc远程调用使用说明&源码

    RPC(Remote Procedure Call)远程过程调用是一种计算机通信协议,允许一个程序在某处执行,通过网络调用另一台计算机上的程序,就像它是一个本地函数一样。这种技术在分布式系统和微服务架构中广泛使用,简化了不同...

    学习使用Python实现RPC远程过程调用.zip

    Python中的RPC(Remote Procedure Call,远程过程调用)是一种允许程序在不同的计算机上进行通信并调用对方功能的技术。在本教程中,我们将探讨如何使用Python实现RPC,以实现跨进程甚至跨网络的函数调用。 RPC的...

    用RPC机制把本地调用转换成远程调用

    远程过程调用(RPC, Remote Procedure Call)是一种通信协议,它允许在一台计算机上的程序调用另一台计算机上的子程序或函数,而无需程序员明确了解底层通信网络细节。通过RPC机制将本地调用转换为远程调用的能力极...

    rpc远程调用

    RPC(Remote Procedure Call)远程过程调用是一种计算机通信协议,它允许一个程序在一台机器上执行操作并获取另一台机器上的数据,就像调用本地函数一样简单。在分布式系统中,RPC是实现服务间通信的重要手段,使得...

    hessian-demo和hessian与spring整合demo.doc

    Hessian是一个轻量级的remoting on http工具,使用简单的方法提供了RMI...采用的是二进制RPC(Remote Procedure Call Protocol,远程过程调用协议)协议,因为采用的是二进制协议,所以它很适合于发送二进制数据。

    RPC介绍及开发指南

    RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。 客户端在不知道调用细节的情况下,调用存在远程机器上的方法,就像...

    python-rpc框架,基于ws长连接暴露

    python—rpc框架,基于ws长连接暴露RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如...

    分布式 rpc远程调用 dubbo

    分布式RPC(Remote Procedure Call)是一种在分布式系统中实现不同节点间功能调用的技术,它使得开发者可以像调用本地方法一样调用远端服务。Dubbo是阿里巴巴开源的一款高性能、轻量级的Java RPC框架,它提供了丰富...

    rpc服务器不可用是什么意思.docx

    RPC 是英文 Remote Procedure Call Protocol 的简写,中文释义为远程过程调用协议。这是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC 服务器是 RPC 协议的实现,它允许远程计算机...

    gRpc详解(远程过程调用)

    RPC(Remote Procedure Call Protocol,远程过程调用协议)是一种通信协议,它允许在不同计算机上的程序互相调用对方的功能,就好像这些功能在本地一样。这种通信模式基于客户端-服务器架构,其中客户端发起调用,...

    分布式条件下的远程服务调用[参考].pdf

    远程服务调用主要分为两种技术:RPC(Remote Procedure Call)远程过程调用和RMI(Remote Method Invocation)远程方法调用。RPC允许客户端像调用本地函数一样调用远程服务器上的函数,通过Stub和Skeleton实现数据...

    dubbo-rpc-api-2.5.3.jar包

    RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息...

    Implementing Remote Procedure Calls

    远程过程调用(Remote Procedure Call,简称RPC)是一种通过网络在不同计算机之间进行通信的技术。它允许客户端应用程序通过网络调用服务器端的过程或函数,而无需了解底层网络协议细节。这种机制使得分布式系统的...

Global site tag (gtag.js) - Google Analytics