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

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

兼容的无差别跨语言调用

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

支持浏览器端的跨域调用

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

性能卓越,使用简单

python rpc webservice_关于RPC、HTTP、WebService的区别相关推荐

  1. 转载-- http接口、api接口、RPC接口、RMI、webservice、Restful等概念

    http接口.api接口.RPC接口.RMI.webservice.Restful等概念 收藏 Linux一叶 https://my.oschina.net/heavenly/blog/499661 ...

  2. http接口、api接口、RPC接口、RMI、webservice、Restful等概念

    在这之前一定要好好理解一下接口的含义,我觉得在这一类中接口理解成规则很恰当         http接口:基于HTTP协议的开发接口.这个并不能排除没有使用其他的协议. api接口:API(Appli ...

  3. 「RPC」简述RPC

    RPC是什么 RPC(Remote Procedure Call)远程过程调用协议,一种通过网络从远程计算机上请求服务,而不需要了解底层网络技术的协议.RPC它假定某些协议的存在,例如TPC/UDP等 ...

  4. RPC编程:RPC概述和架构演变

    RPC编程系列文章第一篇 一:引言 1:本系列文章的目标 2:RPC的概念 二:架构的演变过程 1:单体架构 1):概念 2):特点 3):优缺点 2:单体架构水平扩展 1):水平拓展的含义 2):水 ...

  5. Dubbo之HTTP RPC vs Dubbo RPC性能压测

    公司内部的RPC框架,经过长时间的发展,已经由完全自研演进到底层替换为Dubbo实现,但使用方式(API)还是不变.由于使用了PB序列化协议,以及业务码+操作码定义接口的方式,非常影响开发效率,可理解 ...

  6. 替代GDA中的获取rpc函数poDataset->GetMetadata(“RPC“)

    使用gdal获取经纬度可以通过API this->poDataset->GetMetadata("RPC")来自动实现定位rpc文件,并且将内容读入到char** pa ...

  7. 【RPC框架、RPC框架必会的基本知识、手写一个RPC框架案例、优秀的RPC框架Dubbo、Dubbo和SpringCloud框架比较】

    一.RPC框架必会的基本知识 1.1 什么是RPC? RPC(Remote Procedure Call --远程过程调用),它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络的技术. ...

  8. 从零实现RPC框架1:RPC框架架构设计

    从零实现RPC框架1:RPC框架架构设计 1.什么是 RPC? RPC 的全称是 Remote Procedure Call,即远程过程调用.简单解读字面上的意思,远程肯定是指要跨机器而非本机,所以需 ...

  9. 远程过程调用RPC 2:RPC思想与RPC框架

    RPC思想与RPC框架 RPC思想 组成部分 RPC框架 完整的RPC框架 RPC调用关键点 RPC框架分类对比 RPC和REST REST主要原则 对比 RPC思想 上一篇笔记:远程过程调用RPC ...

最新文章

  1. 一个java删除文件夹的小方法
  2. JavaScript 为什么要有 Symbol 类型?
  3. gta5线上小助手_gta5线上助手(xiu改器)使用
  4. JQuery 总结(5) 总结各种小应用
  5. 微型计算机只能使用机器语言,道计算机等级考试精选题全.doc
  6. 周至四中计算机老师,周至县第四中学顺利承办周至县 “教育信息化技术与教学课堂深度融合交流研讨会”...
  7. 用VML画图(一些基本的矢量图)(转)
  8. 中国长租公寓市场白皮书
  9. 解决int和Integer不能互转
  10. vue router children 路由变了 组件没变_Vue.js从零开始——路由(2)
  11. 基于增量更新的协同过滤
  12. wildfly access log 开启
  13. 手机论文查重软件哪个靠谱?
  14. 基于javaweb的宠物医院管理系统
  15. java在线编译功能
  16. 印象笔记Markdown样式美化
  17. sklearn机器学习之分类决策树(泰坦尼克号幸存者数据集)
  18. 项目合同管理 试题分析
  19. 有限元基础及ANSYS应用 - 第8节 - 梁系结构的ANSYS分析
  20. 【金猿案例展】某大型股份制银行——指标的统一管理和分析平台

热门文章

  1. C++ 判断元音/辅音
  2. android 跟随动画,Android实现View拖拽跟随手指移动效果
  3. sr650服务器cpu型号,至强Gold 联想ThinkSystem SR650评测
  4. 判断文件是否改变php,PHP判断文件是否被修改实例
  5. 计算机应用技木就业前京,计算机专业毕业的研究生在京就业情况及启示.doc
  6. [Git GitHub] Windows下安装git,从0开始搭建git环境(配置环境变量+设置git-ssh key...配置)(超全版)
  7. 软件工程--第一周学习进度
  8. 关于(int argc char **argv)
  9. Python之路 day1 基础1 变量 for while 用户输入
  10. Posix共享内存区