传统的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、微服务之间
整理了RPC和RESTful服务调用方式的区别,详细介绍了RPC和RESTful的基本内容、架构、核心组件以及两种方式的对比
本书包括以下内容: ·强调Web基础技术的力量 —— HTTP应用协议、URI命名标准与XML标记语言 ·介绍面向资源的架构(ROA),设计RESTful Web Services的常识规则集合 ·揭示RESTful的设计如何比远程过程调用(RPC)...
OrderInterceptRelease dubbox+angular+queryBuilder 1、技术点 dubbox restful angular restangular jQuery-QueryBuilder 生成过滤sql bootbox 提示框 2、TODO 权限
什么是DelphiMVCFramework DMVCFramework是一个非常流行的Delphi框架,它为Delphi开发人员提供了易于使用,可伸缩,灵活的RESTful , JSON-RPC和ActiveRecord框架。 DMVCFramework是GitHub上最受欢迎的Delphi项目,...
http://127.0.0.1:5555/restful/rpc { "db":"mycon1","function":"sp_fun_test", "in1":10.1,"in2":"就是这么简单" }
REST上的eProsima RPC通过RESTful范式提供RPC通信。建造该存储库提供脚本来构建和安装RPC库。 同样在您可以找到使用自动工具Linux软件包和Windows的二进制文件。 以下小节解释了如何使用 CMake 为每个 RPC 库进行树...
本文展示了Http协议的强大能力,如何定义什么是Restful Web Service架构以及以当今RPC式Web服务的对比,并解析了Restful Web Service架构的四个特征:可寻址性、无状态性、连通性和统一接口.
本文讲述了什么是REST远程调用,已经在开发时如何做到符合REST规范的调用接口
本文展示了Http 协议的强大能力, 如何定义什么是Restful Web Service 架构以及以当今RPC 式Web 服务的对比,并解析了Restful web Service 架构的四个特征:可寻址性、无状态性、连通性和统一接口。
RESTful架构: (1)每一个URI代表一种资源; (2)客户端和服务器之间,传递这种资源的某种表现层(Representation); (3)客户端通过四个HTTP动词,对服务器端资源进行操作,实现"表现层状态转化"。 Hessian:...
深沉的 deepjs 的同构 Restful 集合操作。 这个库带有: 一个内存集合管理器,它定义了与任何其他 deepjs 客户端完全相同的 API。... rpc(方法,参数,id) 批量(动作) 并为集合定义了additi
SOFARPC 概述 SOFARPC是一种高性能,高可扩展性的生产级Java RPC框架。 在Ant Financial中,SOFARPC已经使用了十多年,并且已经发展了五代。 SOFARPC致力于简化应用程序之间的RPC调用,并为应用程序提供方便,无代码...
1、采用jersey restful spring mybatis alibaba.druid连接池 json 技术搭建的一套rpc通信架构; 2、支持 mysql 、oracle 数据库
该项目的目的是为OpenERP的XML-RPC Web服务提供RESTful“代理”。 我们旨在以这样一种方式来构建API: 第三方应用程序与OpenERP进行通信变得更加容易(通过使API易于理解并提供指向链接的资源和工作流的超链接),...
介绍HTTP-RPC是一个开放源代码框架,用于在Java中创建和使用RESTful和类似REST的Web服务。它非常轻巧,仅需要Java运行时环境和servlet容器。整个框架的大小约为100KB,使其成为需要最小占用空间的应用的理想选择。本...
用于用户和用户API的RESTful和JSONRPC API 登录/注册/个人资料视图 用户文件管理 媒体文件管理 系统状态管理员 要求指南 具有JSONRPC支持的RESTful: 用户基础 GET user/* :查看路线 POST user/api/login :登录 ...
前端开源库-coloredcoins-rpccolored coins rpc,node.js中的彩色coins restful api服务器包装
h2object/rpcRPC for normal HTTP request with a special response Analyser interface.鉴于各种基于HTTP的Restful服务, 抽象出常用请求接口, 同时提供HTTP响应分析接口, 适配各种不同的Restful应用的响应。...