报名参加CloudWeGo黑客松,奖金直推双丰收! 了解详情
写点什么

WebSockets 与 REST 之争?

  • 2012-03-01
  • 本文字数:2323 字

    阅读完需:约 8 分钟

在过去的几年中, WebSockets 变得越来越流行并积累了不少用户。去年年底,WebSockets 成为了 W3C 的推荐候选,这使得其向标准更迈进了一步。Oracle 等其他厂商最近也提交了申请,来启动在 Java 企业版的下一个版本中引入 WebSockets( JSR 356 )的标准流程工作。绝大部分的主流浏览器,如 Chrome、Firefox、Safari 和 IE,都支持某个 WebSockets 修正本,并最终会采用最后成形的标准。在较短时间内 WebSockets 几乎已经成为了 Web 不可分割的一部分。尽管如此,仍有一些开发者对 WebSockets 将会如何或者是否能够融入到 Web 架构风格:REST 持保留意见。有一些人,如 Nathan Evans,针对这一问题则表示 WebSockets 会使得 REST 相形见绌:

在仔细研读了 WebSockets 标准并吸收了各种相关的在线讨论后,我越来越清楚地了解到该标准打算窃取 RESTful web 服务所分享的绝大部分想法。我想说的是,将来在产品开发的某个阶段,一定会有人提出这么一个问题: “好吧伙计们,在这个项目中我们是应该使用 WebSockets 还是 REST?”

我预计 WebSocketes 将在一到两年内,开始阻碍 RESTful web 服务的发展——至少依目前的形势来看是这样的。

Nathan 在其文章中认为就他使用 REST 的经验来看,其实 REST 并不像有些人描绘的那样是所谓的“杀手锏”,当然了在他看来 WebSockets 也不尽完美。他随后罗列了几个为何 WebSockets 会成为 REST 威胁的原因,如 REST 框架依赖于标准较低的基于文本的协议。相对于 REST,WebSockets 提供了包括双向交互在内的一些较为重要的利好:

WebSockets 所提供的真正的双向交互能力对任何衍生于 HTTP 的协议来说,都是前所未有的。这种能力既不被 SOAP 也不被 REST 所拥有。而 Comet/ 推(push)/ 长轮询(long-polling)也只能模拟,而且效率并不高。双向交互能力从根本上说是相当好的,只要你愿意,你可以在 WebSocket 之上的远程桌面或 VNC 开通一个实时 TCP 协议通道。

Nathan 坚信 WebSockets 带来的诸多好处远超 REST(HTTP)所能提供的,开发人员终将会选择转移到 WebSockets 上来。

对那些需要较高可视性且跨平台的可交互 web 服务的项目来说,REST 可能还将是其默认选项。而对于没有上述要求的项目而言,WebSockets 将有机会取而代之,运行在其之上的要么是 JSON,要么使用自定义的端协议。[……] 尽管两者是竞争关系,但好在 REST 和 WebSockets 其实可以相互共存。事实上,由于它们都是在 HTTP 基础之上衍生的,所以两者是可以兼容的。

然而,Nathan 不是唯一一个抛出“使用 WebSockets 还是 REST”这类问题的人。比如, Shay Bannon 早在 2010 年就提出是否有可能在使用 WebSockets 时利用 REST 的一些原则:

首先要搞清楚的是,你如何来描述一个 URI?其次,如何描述 HTTP 方法(GET、PUT、POST 等)?最后,如何描述 HTTP URI 参数和消息头?似乎可以通过往消息内容(文本字符串)中构建某些模式(schema)的方法来解决。就像一个包含“uri”、“params”等域的 JSON 字符串那样。这样想就太复杂了,因为使用 HTTP,你可以创建一个非常简单的防火墙,只简单利用消息头或参数,而无需解析消息体……

他想知道为何 WebSockets 没有 URI 或消息头的概念,这样看来,在大家重新改造 REST 并导致所谓的“非统一风格”之前,是否需要一个在 WebSockets 之上的 REST 规范?那个时候他收到了很多人对此文章的回应。比如,其中一个声称自己之前在一家 WebSockets 公司工作的人(所以其观点可能不太客观)回复道:

REST 和 WebSocket 通信看起来是两种不同的分布式计算风格。REST 就像传统派,在 HTTP 之上,同步的 web rpc 风格。WebSockets 则像新兴派,是 HTTP 的延伸,通常是异步的 web 通信风格。恕我直言,长远来看,WebSocket 将会极大的减少对 WAN 计算的 REST 需求。使用 WebSocket,那些在过去几十年中我们所熟知和喜爱的协议都可以在 web 上得以扩展,而无需担心映射到 HTTP 上的笨拙和性能短板。

另外也有人回复道:

我的想法是 REST 引入了传统的请求 / 应答范例。相反,WebSockets 迎合了 comet/ 长轮询的场景,其通信范围可以在几个通信周期中保持开放。并且,WS 最初的握手仍然发生于 HTTP,所以实际上,它们并不相互排斥。我也认为 WS 协议的要点在于摆脱 HTTP 消息头的鬼把戏,因为它已经变得冗余,只会凭添消息负载。

然而,虽然基本达成 REST 和 WebSockets 能够也应该共存的共识,但一些留言者完全不认同关于在 WebSockets 之上的 REST 的概念,其中有人谈到:

如果你以 Fielding 的观点来考虑 REST,将其作为一种可定位对象(或资源)的 web,那么这在双重通信格式上是行不通的。你不能指望资源能自己发起会话。WebSockets 将会转换 web(如果它们发起的话),但不是作为针对 REST 风格通信的一种协议。

还有人给出了该观点的更深细节分析:

WebSockets 就像用 ADD 通话的两个人。完全是双向的,两边都可以同时说话,在对方讲话时,两边也都要拿起自己的听筒。REST 是无状态以及同步的,只处理请求 -> 回应。你只能自己扩展 REST 的概念以期得到服务器(主动发起)-> 客户端通信的利好。我可以看到 WebSockets 中存在一个实现 REST 的库,但这只对已经拥有 RESTful API,并想得到削减开销的利好(一个连接即可,无需重构其代码)的应用有用。

当然了,在 REST 社区也存在一些人,比如Jim Webber ,他们坚信WebSockets不会给web 带来好处

Jim Webber tweet

随着WebSockets 几乎已经成为了一种标准,而且被浏览器、移动设备以及所支持和使用,我们倒很有兴趣来了解一下这会对那些当前使用REST 和HTTP 的开发者带来多大影响,或者会被一个不同的开发者团体所接受?更糟的是,是否像某些人所坚信的那样,我们已经处在“Web 正在被破坏”的危险之中?

查看英文原文: WebSockets versus REST?

2012-03-01 07:337897
用户头像

发布了 52 篇内容, 共 20.1 次阅读, 收获喜欢 3 次。

关注

评论

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

沈阳等级保护测评机构有哪些?有几家?在哪里?

行云管家

等保 等级保护 等保测评 沈阳

教你学会使用Angular 应用里的 export declare const X Y

华为云开发者联盟

前端 华为云 华为云开发者联盟 企业号 6 月 PK 榜

2023-06-26:在大小为 n x n 的网格 grid 上,每个单元格都有一盏灯,最初灯都处于 关闭 状态 给你一个由灯的位置组成的二维数组 lamps 其中 lamps[i] = [rowi,

福大大架构师每日一题

Go 算法 rust 福大大架构师每日一题

DataLeap的全链路智能监控报警实践(二):概念介绍

字节跳动数据平台

如何驯化机器狗读懂人类手势,手把手教你!

飞桨PaddlePaddle

人工智能 百度 paddle 飞桨

6个常见的IB网络不通问题

华为云开发者联盟

后端 开发 华为云 华为云开发者联盟 企业号 6 月 PK 榜

【直播预告】HarmonyOS极客松赋能直播第二期:数据库与网络连接开发

HarmonyOS开发者

HarmonyOS

专场来袭,深度解读阿里云视频云的全智能进化

阿里云CloudImagine

云计算 阿里云 视频云

前端文件上传的几种交互造轮子 | 京东云技术团队

京东科技开发者

前端 Vue3 文件上传 文件上传下载 企业号 6 月 PK 榜

报名开启!2023大模型应用创新挑战赛来啦

飞桨PaddlePaddle

人工智能 百度 paddle

用代码玩转迷你图:手把手教你用编程语言打造简洁易读的数据图表!

不在线第一只蜗牛

代码 框架开发

Hive执行计划之只有map阶段SQL性能分析和解读

不在线第一只蜗牛

sql 开发语言 开发框架

数据库性能优化必读,AntDB-M数据库的哈希索引设计

亚信AntDB数据库

数据库 AntDB AntDB数据库 企业号 6 月 PK 榜

inBuilder低代码平台特性推荐系列-第四期

inBuilder低代码平台

这问题巧了,SpringMVC 不同参数处理机制引发的思考 | 京东云技术团队

京东科技开发者

spring springmvc HTTP 请求方式 企业号 6 月 PK 榜

焱融构建多云数据存储平台 重塑云中数据活力

焱融科技

文件存储 高性能存储 #分布式文件存储

精选8道ES高频面试题和答案,后悔没早点看。

王中阳Go

elasticsearch 面试题 go面试题 后端面试题 ES面试题

喜报:Apache Flink 荣获 2023 年度 SIGMOD 系统奖 !!!

Apache Flink

大数据 flink 实时计算

磐舟磐基平台:基于KubeEdge的落地实践

华为云开发者联盟

云原生 后端 华为云 华为云开发者联盟 企业号 6 月 PK 榜

从2PC和容错共识算法讨论zookeeper中的Create请求 | 京东云技术团队

京东科技开发者

zookeeper 分布式事务 zookeeper分布式锁 企业号 6 月 PK 榜 容错共识算法

JavaScript 实践+理论(总结篇):作用域、闭包、this、对象原型

沉浸式趣谈

闭包 原型链 作用域 this 原型模式

基于 LRU-K 模型如何实现高效的元数据缓存?

焱融科技

#高性能 #文件存储 #分布式存储

NFTScan | 06.19~06.25 NFT 市场热点汇总

NFT Research

热点 NFT\ 市场

福昕软件与北信源达成战略合作,构建PDF文档安全新格局

新消费日报

堡垒机的作用以及价格简单说明-行云管家

行云管家

网络安全 堡垒机 IT运维

h2database BTree 设计实现与查询优化思考 | 京东云技术团队

京东科技开发者

数据库 索引 B+tree 企业号 6 月 PK 榜 h2database

ClickHouse数据表迁移实战之-remote方式 | 京东云技术团队

京东科技开发者

Clickhouse 数据迁移 Remote 迁移数据 企业号 6 月 PK 榜

云游世界NFT卷轴游戏dapp系统开发合约定制

开发微hkkf5566

百度召开CVPR首个大模型研讨会,吸引超1000支队伍参与文心大模型国际比赛

新消费日报

WebSockets与REST之争?_REST_Mark Little_InfoQ精选文章