博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
RPC(远程过程调用)是什么
阅读量:6089 次
发布时间:2019-06-20

本文共 1916 字,大约阅读时间需要 6 分钟。

  hot3.png

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 甚至支持推送。

具有良好的可扩展性,可以通过过滤器和中间件实现加密、压缩、缓存、代理等各种功能性扩展。

兼容的无差别跨语言调用

支持更多的常用语言和平台

支持浏览器端的跨域调用

没有中间语言,无需学习成本

性能卓越,使用简单

转载于:https://my.oschina.net/xwzj/blog/889365

你可能感兴趣的文章
嵌入式编程 相关 细节 收集
查看>>
POJ 3321:Apple Tree(dfs序+树状数组)
查看>>
mxnet 源码阅读 8
查看>>
Cocos2d-x学习之---关于CCTableView中reloadData()操作,删除第一个/最后一个cell后tableview位置未刷新的问题...
查看>>
SDL2.0的SDL_Event事件处理
查看>>
linux系统忘记root密码的解决办法--(超细致讲解!)
查看>>
linux下配置远程登录
查看>>
synchronized 与 Lock 的那点事
查看>>
Convert From One Currency to Another
查看>>
读书:大话存储
查看>>
Android HttpClient
查看>>
优化枚举法
查看>>
Container With Most Water
查看>>
安全测试回顾(一)补充:burp 的基本操作
查看>>
iOS 音频视频制作
查看>>
Mac下自带shell连接linux乱码问题
查看>>
vue数据双向绑定原理-wather
查看>>
矢量图
查看>>
C++11范围for循环
查看>>
【转载】windows使用nginx实现网站负载均衡测试实例
查看>>