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

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

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

兼容的无差别跨语言调用

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

支持浏览器端的跨域调用

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

性能卓越,使用简单

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574787.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python程序发布 ubuntu_将Windows项目发布到Ubuntu服务器详细教程(Windows编程,Ubuntu服务器做解释器)...

前期准备(1)专业版Pycharm(社区版没有deployment功能),学生,教师可申请免费专业版,详情可看我的博客。(2)可通过SSH连接Ubuntu服务器,并且服务器安装了Python解释器。部署本地Pycharm项目到Ubuntu服务器1.点击Tools - Deployment …

nios 双核 烧录_nios程序烧写到epcs方法

折腾了好久,才把nios程序烧写到epcs的方法弄明白。开始先在网上搜了下,这方面资料很多,看了半天也没怎么弄明白,无奈,只好去找官方文档,看完后,只想说,官方文档确实给力。下面列出参…

access百度翻译 get_Asp.NET调用百度翻译

Asp.NET调用百度翻译,图示:HTML:OA翻译TextMode"MultiLine">源语言:自动检测中文英文日文目标语言:自动检测中文英文日文runat"server" Text"翻译" οnclick"Translate_Click" />C…

angular js 默认选中_AngularJS Select(选择框)

下拉框默认的值为 key-value 对中的 value ,也可以用 as 来修改下拉框的值。也就是 x for (x, y) 相当于是 y as x for (x, y)。as 前面的为下拉框的值,后面的为下拉框显示的内容。​也可以不使用key-value 对中的 value 作为下拉框的值, 直接使用对象的…

【Qt之Quick模块】6. QML语法详解_1 基础语法与三种导入语句

前言 通过以上1-5文档的介绍,Quick与QML的概念及QML语法、类型、文件作用等已叙述个大概,接下来是对QML语法进行展开来说。 其实,学习任何一门语言或者做任何一件事情,并不用一开始就要求尽善尽美,做个无懈可击&…

datagrip将一个数据库中的数据_跨平台数据库管理神器DataGrip,用上就爱不释手...

原文链接:https://www.ffeeii.com/2041.htmlDataGrip是Jetbrains旗下众多优秀的效率生产工具之一。下载地址:https://www.jetbrains.com/datagrip/DataGrip是多引擎数据库环境,支持几乎常见的数据库类型:PostgreSQL、MySQL、Oracl…

栅格单元值的选取方法_ArcGIS中栅格数据重采样方法

2.用ArcGIS中的Resampling工具进行栅格重采样操作在ArcToolbox中依次找到Data Management Tools—>Raster—>RasterProcessing—>Resample工具,工具界面如下图所示:其中各参数含义如下:Input raster: 输入栅格数据集Output raster d…

城市轨道交通运营管理属于什么院系_专业介绍|城市轨道交通运营管理专业

原标题:专业介绍|城市轨道交通运营管理专业专业介绍丨城市轨道交通运营管理专业▲▲▲汽车工程系简介THE FIRST汽车工程系目前开设了汽车检测与维修技术、城市轨道交通运营管理、城市轨道交通通信信号技术等专业,在校学生700余人。汽车工程系突出复合型技…

idea 鼠标变量_IntelliJ IDEA鼠标悬停方法显示Java Doc

本问题已经有最佳答案,请猛点这里访问。我正在使用IntelliJ IDEA 9,是否可以配置IDEA,以便在将鼠标悬停在某个方法上时,IDEA会调出Javadoc(与CTRL Q相同)?看来,此功能可能最终会进入IntelliJ IDEA 12.1或1…

ad18敷铜为什么打的孔里面也有_PCB覆铜后放置大量过孔有什么作用?具体怎么放置?...

底层 顶层 共地下面摘抄的:过孔的多少不等同于决定某种实际的意义!大家都知道在高频情况下,印刷电路板上的布线的分布电容会起作用,当长度大于噪声频率相应波长的1/20 时,就会产生天线效应,噪声就会通过…

python程序写完后点哪个运行快_让 Python 代码运行更快的最佳方式!

PyPy与CPythonPyPy是Python解释器CPython的直接替代品。CPython将Python编译为中间字节码然后由虚拟机解释,而PyPy使用实时(JIT)编译将Python代码转换为本地机器的汇编语言。根据正在执行的任务,性能提升可能会非常显着。平均而言,PyPy将Pyth…

idea下拉项目_推荐几款非常好用的IDEA插件(香)

每天进步一点点,坚持下去,你总是会不一样的。加油!最近在整理Java常用的一些基础、ZooKeeper、Spring全家桶、源码、Dubbo、Elasticsearch、Redis、MySql、RabbitMQ、Kafka、Linux 、微服务等技术栈。持续更新中,欢迎点上面后端架…

python批处理代码_【原创源码】【python】python文本文件批处理

[Python] 纯文本查看 复制代码import osimport shutildef text_edit_vhd(filepath):with open(filepath,r) as file_head:content file_head.read()file_head.seek(0,0)file_head.write("protect begin \n" content)file_head.seek(0,2)file_head.write("\npr…

php 汉王云名片_汉王云-名片识别【最新版】_OCR_人工智能_API-云市场-阿里云

{"moduleinfo":{"advanList_count":[{"count_phone":4,"count":4}],"title":"云市场服务保障体系","mapList_count":[{"count_phone":4,"count":4}]},"advanList":[{&qu…

git 如何提取已提交的文件_git取两次提交的文件列表,包含目录信息

1.用git rev-list HEAD取得版本号列表:在SmartGit中看到的也是这样,验证了我们的猜想:取到两个版本号之后,用git diff命令:git diff [--options] ... [--] […​]这里的[-options]我们填的是--name-status,…

filco的pin码_一把强行帮你退烧的键盘 plum niz atom66静电容

一把强行帮你退烧的键盘 plum niz atom66静电容2019-09-10 10:37:578点赞17收藏14评论小编注:此篇文章来自即可瓜分10万金币,周边好礼达标就有,邀新任务奖励无上限,点击查看活动详情说起niz,正是个神奇的牌子,老板一个人就负责制作…

在fritzing中怎么导入_电路图制作软件(Fritzing)

Fritzing,图形化Arduino电路开发软件。Fritzing是个电子设计自动化软件。它支持设计师,艺术家,研究人员和爱好者参加从物理原型到进一步实际的产品。还支持用户记录其阿尔杜伊诺和其他电子为基础的原型,与他人分享,在教…

得力助手 消防员的 消防机器人_消防机器人市场如今的发展现状,是否能成为消防员的得力助手...

随着经济的不断发展,使消防和应急救援的要求越来越高。基础工业的快速发展也使得易燃、易爆和剧毒化学品引发火灾的可能性越来越高。一方面,今天的消防需要更详细的消防信息和更快的消防和救援速度。另一方面,在改革后的消防系统建立后&#…

自己配置python环境_windows下python环境的配置

1 安装python类似其他软件,点击下一步就行了注意选择把python.exe加入到path中,当然也可以自己手动配置验证python是否安装成功>>>后面输入代码,可以立即看到结果,c语言等利用{}来界定代码块,python利用缩进来…

ora 00900 已编译但有错误_技术分享|万万没想到!编译错误竟然还没灭绝???

CodeWisdom-技术分享万万没想到!编译错误竟然还没灭绝???复旦大学CodeWisdom团队的代码分析和挖掘小组针对开源软件项目持续集成过程中出现的编译错误,进行了大规模的经验研究。该研究分析了常见的编译错误类型、修复代…