写点什么

REST“皈依者”日记

  • 2011-07-22
  • 本文字数:1369 字

    阅读完需:约 4 分钟

就在每个人都认为 REST 相关的论战应该停息的时候,新的一轮 REST 文章浪潮却紧跟而上。正如 Mark Little看到的

公平地说,只要提到 REST,就会引发争论……

延续这一趋势,Ronald Schmelzer 发表的新作中谈到为什么以及如何从 Web Service 转向 REST。

据 Schmelzer,也即 ZapThink 认为:

REST 是一种分布式软件架构风格,它可以替代人们普遍接受的基于 XML 的 Web Service 实现系统间的整合……当我需要实现一个服务,当然在此之前我已经分析过该服务的必要性了,我会面临两种选择:Web Service 或 REST 风格的服务。从下列理由可以看出,而我而言,REST 明显胜出。

这段话本身就很有意思,因为它与 Dhananjay Nene 先前提出的观点是直接对立的:

面向服务既不是 REST 的核心,也不是 REST 的目标。REST 不是面向服务的,面向服务与 REST 也不相干……REST 并不想变成面向服务。这是因为它不把流程当作任务的序列来执行。它把流程看作一组不断修改的资源序列。换言之,它将流程看成一组角色,它们之间不断地交换资源(或文档),并且基于接收的资源来执行活动。

因此,Schmelzer 所谈论的似乎不是 REST,而是人们通常所说的 RESTful Web Service,这是一种使用 REST 技术构建 SOA 的方法。尽管通常称之为 REST,但这种方法与本真的 REST 没有关系,而且它类似于 POX(plain old XML over HTTP),不过与 POX 不同的是,它不仅支持 XML,还支持其他数据类型,比如 JSON(JavaScript Object Notation)、ATOM、二进制数据块。而且,它不像 POX 那样通常只基于 GET 和 PUT,它基于更多的 HTTP 方法。

Schmelzer 继续谈到:

……选择 REST 的原因有很多,但是最主要的原因是简单……REST 比 Web Service 更易于使用和理解。开发 REST 更方便、更快捷……而且,这也是为什么大多数最流行的 Web API 基于 REST 开发的原因……不过,除了简单外,我还很喜欢 REST 方法的优雅。基本操作和 Web 的扩展性是 REST 方法的底层基础。HTTP 操作是标准的、广泛接受的、便于理解的、在操作上一致的……

以上这些是任何一篇 REST 文章中都包含的 REST 的经典优点,但是对于 ZapThink 这么知名的分析公司来说,人们总是希望能看到更多细节。

回到架构问题上,Schmelzer 继续写到:

因此,如何将 SOA 的基本信条与 REST 实现方法结合起来?……REST 是一种架构风格,不是一种实现。而且,Web 和 HTTP 协议正好就是基于这种协议而设计的。

不幸的是,直到文章末尾 Schmelzer 也没有回答这个问题。它继而转向讨论 XMPP 协议的使用,但却没有解释两种架构风格(ROA 和 SOA)是怎么结合的。

Schmelzer 在文章的结尾说:

我不认为 REST 或 Web Service 是可以当作宗教般信仰的对象,以至于对它至死不变。话虽如此,在过去十几年中,垄断供应商、开发者和企业架构师们一直强调,正确实施 SOA 必须使用 Web Service……实施 SOA 无需 Web Service 就能做得很好。SOA 相关的讨论是架构层面的讨论——过去十年中我们谈论的所有东西对于 REST 或 Web Service 是同等适用的,不论它们基于哪种协议、基础设施或数据格式。优秀的企业架构师在架构这一抽象层次上工作,而将实现细节留给那些关心如何将 SOA 原则应用于实践的人们。

所以,REST 优于 Web 服务的讨论仍然在继续。那么,是否应该将本真的 REST 作为实现 SOA 的基础?仍然缺乏依据。


查看英文原文: The Diary of a REST “Convert”

2011-07-22 09:163039
用户头像

发布了 184 篇内容, 共 79.0 次阅读, 收获喜欢 7 次。

关注

评论

发布
暂无评论
发现更多内容

推动开源行业高质量发展|2023开放原子全球开源峰会圆满落幕

开放原子开源基金会

开源 开发原子全球开源峰会 开发原子

公有云数据库新趋势,企业降本增效正当时

MatrixOrigin

数据库 分布式 云原生 超融合 HTAP

如何成功实施一个数据治理项目?实施步骤有哪些?

袋鼠云数栈

数字化转型 数据治理 企业号 6 月 PK 榜

火山引擎DataLeap:一个易用、高效的数据目录,是如何搭建的?

字节跳动数据平台

大数据 数据治理 数据目录 数据研发

《中国电子报》专访简丽荣:“模型热”将引发云计算与数据库行业大变革

酷克数据HashData

打造科学新高地|2023开放原子全球开源峰会科学智能分论坛圆满举行

开放原子开源基金会

开源 开放原子全球开源峰会 开放原子 科学智能

Battery Indicator for Mac:Mac笔记本电脑电池电量剩余百分比显示工具

背包客

macos Mac软件 MacBook Pro Battery Mac电量显示软件

如何用Taro打造敏捷的移动App架构

没有用户名丶

万物云原生下的服务进化 | 京东云技术团队

京东科技开发者

Java 云原生 镜像 GraalVM 企业号 6 月 PK 榜

“升级数智底座”中央企业创新发展沙龙在中国科技城(绵阳)举办!

用友BIP

数智底座 数智平台

用友承办全国两化融合标委会工业互联网管理标准工作组全体成员大会圆满召开

用友BIP

工业互联网

深度学习应用篇-元学习[13]:元学习概念、学习期、工作原理、模型分类等

汀丶人工智能

人工智能 深度学习 元学习 元强化学习 6 月 优质更文活动

用友入选信通院“铸基计划”IPaaS标准贡献单位

用友BIP

数智平台

你应该搞懂的 C 语言头文件路径问题

矜辰所致

C语言 头文件 6 月 优质更文活动

南宁建宁水务集团财务共享、全面预算项目正式启动

用友BIP

银行数字化转型研究与敏捷转型探索

L3C老司机

数字化转型 敏捷转型 敏捷组织 银行转型 敏捷探索

体验 TDengine 3.0 高性能的第一步,请学会控制建表策略

爱倒腾的程序员

涛思数据 时序数据库 #TDengine

重庆企业购买堡垒机选择哪家好?理由有哪些?

行云管家

网络安全 堡垒机 重庆

河北国控携手用友探索数智司库,加快建设世界一流

用友BIP

全球司库

OpenAI发布ChatGPT函数调用和API更新

楚少AI

openai GPT-4 ChatGPT4 chatgpt api gpt-3.5-turbo-16k

北京国际开源社区正式启航

开放原子开源基金会

开源 开放原子全球开源峰会 开放原子 北京国际开源社区

还在为618电商推送方案烦恼?我们帮你做好了!

HarmonyOS SDK

HMS Core

牛逼!Windows竟然也能运行QEMU虚拟机!

吴脑的键客

qemu windows10 windows 11

推动绿色计算 共迎绿色未来|2023开放原子全球开源峰会绿色基础设施技术分论坛圆满收官

开放原子开源基金会

开源 开放原子全球开源峰会 开放原子 绿色基础设施技术

2023 年最适用于工业物联网领域的三款开源 MQTT Broker

EMQ映云科技

物联网 mqtt mqtt broker

软件测试/测试开发丨Python类与对象学习笔记

测试人

Python 程序员 软件测试 测试开发 类与对象

大促质量备战之三化战役:“常态化、精细化、一体化” | 京东云技术团队

京东科技开发者

测试 质量 电商大促 企业号 6 月 PK 榜

智慧隧道三维可视化管控平台系统

2D3D前端可视化开发

物联网 数字孪生 三维可视化 智慧隧道 智慧公路隧道

深度学习应用篇-元学习[14]:基于优化的元学习-MAML模型、LEO模型、Reptile模型

汀丶人工智能

人工智能 深度学习 元学习 元强化学习 6 月 优质更文活动

REST“皈依者”日记_SOA_Boris Lublinsky_InfoQ精选文章