`
qtlkw
  • 浏览: 308511 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Restful vs RPC

    博客分类:
  • JAVA
 
阅读更多
传统的RPC一般是基于二进制协议的,client发个二进制包过来(然后阻塞),server处理完回复一个包,client收到后醒来。在二进制协议中一般可以在包中加个id来指明回复和请求的对应关系,这样我们就能在一个tcp连接上同时发起多个请求和回复.HTTP这种文本协议也可以加id,但由于一些原因(Content-Length可能缺失),即使加了id也做不到一个连接上同时传多个HTTP消息,所以HTTP协议一般会和server保持多个连接,每个连接上同时最多只有一个HTTP消息。此种”连接池“方式即为HTTP中的”Keep-alive“。所以即使在HTTP上(或任何协议上),我们仍然可以做到高效地发送一个请求过去,阻塞,等待server处理完后,再醒来。这不就是RPC么。所以这儿的选择更多是平衡功能和性能。一般来说,面向终端用户的尽量用Restful HTTP。原因是认知广,直观,编程语言都支持HTTP(包括shell,这样调试起来方便),性能不是那么重要,方便用户share链接。而面向内部系统的话如果机器不多也可以考虑用Restful HTTP,如果机器很多还是尽量用二进制的RPC吧,毕竟性能差距还是很大的。

普通的http请求的数据结构简单,然后是无状态的,不保持长时间的连接,同时因为http包含了一个header,会多传输几个字节,造成优化不极致。

关于 REST 介绍的文章已经很多了,这里只对 RPC 部分做一个介绍:

RPC(远程过程调用)是什么

    简单的说,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

早期的 RPC

    第一代 RPC(ONC RPC,OSF RPC)不支持对象的传递。
    CORBA 太复杂,各种不同实现不兼容,一般程序员也玩不转。
    DCOM,COM+ 逃不出 Windows 的手掌心。
    RMI 只能在 Java 里面玩。
    .NET Remoting 只能在 .NET 平台上玩。

XML-RPC,SOAP,WebService

    冗余数据太多,处理速度太慢。
    RPC 风格的 Web Service 跨语言性不佳,而 Document 风格的 Web Service 又太过难用。
    Web Service 没有解决用户的真正问题,只是把一个问题变成了另一个问题。
    Web Service 的规范太过复杂,以至于在 .NET 和 Java 平台以外没有真正好用的实现,甚至没有可用的实现。
    跨语言跨平台只是 Web Service 的一个口号,虽然很多人迷信这一点,但事实上它并没有真正实现。

PHPRPC

    基于 PHP 内置的序列化格式,在跨语言的类型映射上存在硬伤。
    通讯上依赖于 HTTP 协议,没有其它底层通讯方式的选择。
    内置的加密传输既是特点,也是缺点。
    虽然比基于 XML 的 RPC 速度快,但还不是足够快。

Hessian

    二进制的数据格式完全不具有可读性。
    官方只提供了两个半语言的实现(Java,ActionScript 和不怎么完美的 Python 实现),其它语言的第三方实现良莠不齐。
    支持的语言不够多,对 Web 前端的 JavaScript 完全无视。
    虽然是动态 RPC,但动态性仍然欠佳。
    虽然比基于 XML 的 RPC 速度快,但还不是足够快。

JSON-RPC

    JSON 具有文本可读性,且比 XML 更简洁。
    JSON 受 JavaScript 语言子集的限制,可表示的数据类型不够多。
    JSON 格式无法表示数据内的自引用,互引用和循环引用。
    某些语言具有多种版本的实现,但在类型影射上没有统一标准,存在兼容性问题。
    JSON-RPC 虽然有规范,但是却没有统一的实现。在不同语言中的各自实现存在兼容性问题,无法真正互通。

Microsoft WCF,WebAPI

    它们是微软对已有技术的一个 .NET 平台上的统一封装,是对 .NET Remoting、WebService 和基于 JSON 、XML 等数据格式的 REST 风格的服务等技术的一个整合。
    虽然号称可以在 .NET 平台以外来调用它的这些服务,但实际上跟在 .NET 平台内调用完全是两码事。它没有提供任何在其他平台的语言中可以使用的任何工具。

ZeroC Ice,Thrift,GRPC

    初代 RPC 技术的跨语言面向对象的回归。
    仍然需要通过中间语言来编写类型和接口定义。
    仍然需要用代码生成器来将中间语言编写的类型和接口定义翻译成你所使用的编程语言的客户端和服务器端的占位程序(stub)。
    你必须要基于生成的服务器代码来单独编写服务,而不能将已有代码直接作为服务发布。
    你必须要用生成的客户端代码来调用服务,而没有其它更灵活的方式。
    如果你的中间代码做了修改,以上所有步骤你都要至少重复一遍。

Hprose

    无侵入式设计,不需要单独定义类型,不需要单独编写服务,已有代码可以直接发布为服务。
    具有丰富的数据类型和完美的跨语言类型映射,支持自引用,互引用和循环引用数据。
    支持众多传输方式,如 HTTP、TCP、Websocket 等。
    客户端具有更灵活的调用方式,支持同步调用,异步调用,动态参数,可变参数,引用参数传递,多结果返回(Golang)等语言特征,Hprose 2.0 甚至支持推送。
    具有良好的可扩展性,可以通过过滤器和中间件实现加密、压缩、缓存、代理等各种功能性扩展。
    兼容的无差别跨语言调用
    支持更多的常用语言和平台
    支持浏览器端的跨域调用
    没有中间语言,无需学习成本
    性能卓越,使用简单
分享到:
评论

相关推荐

    Restful、SOAP、RPC、SOA、微服务之间.docx

    Restful、SOAP、RPC、SOA、微服务之间的知识点摘要 一、Restful * 定义:Restful 是一种架构设计风格,提供了设计原则和约束条件,而不是架构,而满足这些约束条件和原则的应用程序或设计就是 Restful 架构或服务...

    REST架构的网络服务

    #### 四、RESTful vs RPC 传统的远程过程调用(Remote Procedure Call, RPC)通常采用复杂的协议栈,如SOAP。相比之下,RESTful设计更加简洁、灵活,易于理解和实现。RESTful服务利用HTTP方法来直接映射到CRUD操作...

    10个高频Spring BOOT面试题

    Restful vs RPC - **RESTful**: 是一种基于HTTP协议的网络应用程序的设计风格和开发方式,易于理解且具有良好的扩展性。适用于需要跨平台、跨语言的系统。 - **RPC**: 远程过程调用,是一种更为传统的服务间通信...

    RESTful WebServices中文版 完整清晰版

    本书包括以下内容: ·强调Web基础技术的力量 —— HTTP应用协议、URI命名标准与XML标记语言 ·介绍面向资源的架构(ROA),设计RESTful Web Services的常识规则集合 ·揭示RESTful的设计如何比远程过程调用(RPC)...

    REST与RPC的区别.pdf

    ### REST与RPC的区别详解 #### 一、概述 在现代软件开发中,特别是分布式系统设计领域,REST(Representational State Transfer)与RPC(Remote Procedure Call)是两种非常重要的服务调用方式。这两种方法各有...

    RESTful Web Services 中文版 高清 PDF 电子书

    REST式设计的优点:REST式设计相较于传统的RPC(远程过程调用)式设计,具有更简单、更灵活、更易于扩展的优势。它更加贴近Web的本质,能够充分利用Web的基础技术如HTTP、URI、HTML等。此外,REST式设计往往能够降低...

    SOAP webserivce 和 RESTful webservice 对比及区别

    SOAP消息通常通过HTTP、SMTP等协议传递,并且支持远程过程调用(RPC)模式,使得调用远程服务就像调用本地方法一样。然而,SOAP的复杂性和重量级特性使其在某些场景下显得效率较低,不适合轻量级和高并发的应用。 ...

    RPC(远程过程调用)

    - RESTful API:虽然不是严格的RPC,但可以实现类似的功能,通过HTTP协议进行资源操作。 5. **RPC的优势与挑战**: - 优势:简化编程模型,隐藏网络通信细节,提高开发效率。 - 挑战:错误处理复杂,网络延迟,...

    OrderInterceptRelease:dubbox(java restful and rpc framework power by dangdang)+angular+queryBuilder

    OrderInterceptRelease dubbox+angular+queryBuilder 1、技术点 dubbox restful angular restangular jQuery-QueryBuilder 生成过滤sql bootbox 提示框 2、TODO 权限

    JSONRPC

    1. **轻量级**:JSONRPC通常比RESTful更轻量,因为请求和响应结构简单,适合低延迟、高吞吐量的场景。 2. **方法调用**:JSONRPC使用函数调用语义,而RESTful基于HTTP方法(GET、POST等),前者更直观,后者更符合...

    理解RESTful架构、Hessian简介、机制、Webservice及cxf介绍

    CXF是一个流行的开源框架,支持SOAP和RESTful两种风格的服务,提供了完整的Web服务栈,包括服务发布、客户端调用、WSDL生成等功能,使得开发者可以轻松地构建和消费Web服务。 总结来说,RESTful架构提供了一种简洁...

    JSON-RPC.rar+服务客户端通信+微服务架构应用

    JSON-RPC与RESTful服务对比 JSON-RPC客户端开发 JSON-RPC服务器端开发 JSON-RPC安全性考虑 JSON-RPC跨域资源共享CORS JSON-RPC与WebSocket结合使用 JSON-RPC在微服务架构中的角色 JSON-RPC高级特性:通知与订阅 JSON...

    RESTful_Web_Services中文版.pdf

    ### REST vs RPC 与传统的RPC(Remote Procedure Call)相比,REST式设计更为简单、多功能且可伸缩。RPC通常依赖于复杂的序列化协议和预定义的服务接口,这可能导致服务的耦合度过高,难以适应快速变化的需求。相比...

    sofa-rpc,sofarpc是一个高性能、高扩展性、生产级的java rpc框架。.zip

    5. **多协议支持**:除了传统的基于HTTP的RESTful接口,SOFA-RPC还支持基于TCP的SOFA协议,提供更高效的数据传输。 6. **丰富的生态**:作为阿里巴巴开源家族的一员,SOFA-RPC与Spring Cloud、Dubbo等其他开源项目...

    使用jsonrpc

    与传统的HTTP RESTful API相比,JSON-RPC更适用于需要低延迟、高效率的实时通信场景。 在实际开发中,我们可能需要使用JSON-RPC库来实现客户端和服务器之间的通信。例如,在Java中,有诸如jsonrpc4j这样的库,它...

    1RESTful API 介绍.md

    #### REST vs RPC 在选择API服务器开发的方式时,常常需要在REST和RPC之间做出选择。RPC相较于REST有一些优势,主要体现在: 1. **性能**:RPC通常使用TCP协议作为传输协议,而REST则直接使用HTTP协议。TCP的效率...

    JsonRpc小实例

    7. JSON-RPC与RESTful API对比:虽然两者都是实现客户端和服务器间通信的方式,但JSON-RPC更侧重于方法调用,而RESTful API则基于资源操作,使用HTTP动词(GET、POST、PUT、DELETE等)来表示对资源的操作。...

    java 使用json-rpc

    随着Web应用程序的发展,前后端分离的架构越来越普遍,JSON-RPC作为轻量级的远程调用协议,可以很好地解决前后端交互的问题,特别是在需要跨域调用时,JSON-RPC比传统的HTTP RESTful API更加便捷。 ### 应用前景和...

    基于 Go 语言构建企业级的 RESTful API 服务 企业级go gin 开发框架 附带源码

    "基于 Go 语言构建企业级的 RESTful API 服务企业级go gin 开发框架 附带源码" 本小册将指导读者如何使用 Go 语言构建企业级的 RESTful API 服务,涵盖了从准备阶段到部署阶段的各个流程。小册的内容包括如何安装和...

Global site tag (gtag.js) - Google Analytics