QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

Google 正制订一项新协议,旨在替换掉 HTTP

  • 2009-11-17
  • 本文字数:1787 字

    阅读完需:约 6 分钟

近日 Google 提出了 SPDY ——运行在 SSL 上的一个应用层协议,该协议旨在替换掉 HTTP,而后者被认为会产生延迟。Google 已经使用 Web 服务器与增强的 Chrome 浏览器开发了一个原型,结果是页面加载速度比以前快了 2 倍。

前一阵 Google 发出的倡议“让Web 变得更快”旨在提高Internet 的速度。该倡议涵盖了几个领域,从构建更快的Web 服务器到更快的浏览器。例如, Page Speed 就是个用来提高网页下载速度的工具。 Google 在开源大量工具的同时又发布了相关的教程以帮助全世界的开发者加快其 Web 站点的速度。

然而 Google 并没有裹足不前,他们开发了一个名为 SPDY(发音为 SPeeDY)的新的应用协议,一旦成功并得到广泛应用的话,SPDY 就会替换掉 HTTP 并彻底颠覆整个 Internet。SPDY 白皮书说要向协议栈下面渗透并替换掉传输层协议(TCP),但 Google 也认识到这样的话部署起来会相当困难,因此他们打算对应用层协议 HTTP 进行改进。

SPDY 白皮书提到了 HTTP 协议中的很多限制,尤其是页面传输时的延迟:

  • 一个请求一个连接。由于 HTTP 一次只能获取一个资源(HTTP 管道很有用,但也只是强制形成一个 FIFO 队列),因此 500 毫秒的服务器端延迟导致无法重用 TCP 通道来处理其他请求,而浏览器则通过发送多个连接来解决这一问题。自从去年以来,浏览器已经将每个域的连接由 2 个调整为了 6 个。
  • 只有客户端才能发送请求。在 HTTP 中,只有客户端才可以发送请求。即便服务器端知道客户端需要某个资源,那它也没有办法通知客户端而只能等待其发出对该资源的请求。
  • 未压缩的请求与响应头。如今的请求头的大小差别很大,从 200 bytes 到 2KB 的都有。随着应用越来越多地使用 cookie 和 user agents 扩展特性,700-800 bytes 的头大小已经变得很常见了。对于 modem 或是 ADSL 连接来说,上行带宽都很低,这种延迟就变得很可观了。降低头中的数据可以改进发送请求的序列化延迟。
  • 冗余的头。此外,有几个头会跨越请求在同一个通道上重复发送。像 User-Agent、Host 和 Accept* 这样的头基本都是不变的,没必要重复发送。
  • 可选的数据压缩。HTTP 对数据进行可选的压缩编码。内容总是应该以压缩格式发送。

SPDY 的一个目标就让页面加载时间降低 50%,同时将浏览速度提升一倍。对一个用户来说,几百毫秒不算什么,但每一毫秒都会对未来高度互联的 Web 应用产生积极的影响。当前 Web 上的内容并不会受到该协议的影响,只有 Web 服务器和客户端需要增强以充分利用该协议。

Google 究竟想用 SPDY 做什么呢?

  • 在单个 TCP 会话上执行多个并发的 HTTP 请求。
  • 通过压缩头以及减少不必要的头来降低当前 HTTP 所占据的带宽。
  • 定义一个易于实现且提升服务器效率的协议。我们希望通过砍掉一些边缘情况来降低 HTTP 的复杂度并定义易于解析的消息格式。
  • 将 SSL 作为底层传输协议以达到更好的安全性且兼容于现有的网络基础设施。尽管 SSL 引入了延迟,但我们相信从长远来看,Web 还是要依赖于安全的网络连接的。此外,要想保证跨越现有代理的通信不被破坏,SSL 也是必须的。
  • 让服务器可以主动与客户端通信并向客户端发送数据。

为了达成这些目标,Google 在 SSL 之上增加了一个会话层来实现 SPDY,这考虑到了“单个 TCP 连接之上会有多个并发、交错的流”。HTTP GET 和 POST 消息格式保持不变,但 SPDY 提出了一个新的“帧格式用于在线路上编码和传输数据”。流是双向的,客户端与服务器端都能开启流。

到目前为止,Google 构建了一个既能处理 HTTP 协议,也能处理 SPDY 协议的内存服务器,代码将在不久后开源。还有一个修改的 Chrome 版本(内部的暂定名为 flip ,也是开源的)运行在 HTTP 和 SPDY 之上。他们还开发了一套测试工具集来保证使用 SPDY 后页面仍能正确下载。这些工具也将于不久之后发布。

原型表明目前的结果还是很不错的:

我们通过模拟的家庭网络连接下载了百强网站的 25 个,只有 1% 的包丢失。每个站点都被下载了 10 次并计算平均的页面加载时间,然后计算所有站点的平均时间。结果表明普通 TCP(没有 SSL)上的页面加载时间要比 HTTP 提升了 27% - 60%,而 SSL 要提升 39% - 55%。

纵然提出了最好的协议,但显然 Google 无法凭借一己之力取得成功,还需要依靠社区的推动与努力来创建一个全新的应用层协议。其他公司对此有何反应呢,让我们拭目以待。

参考资源: SPDY 协议草案规范可以使用SPDY 的Chrome

查看英文原文: Google Works on a Protocol Intended to Replace HTTP

2009-11-17 11:262828
用户头像

发布了 88 篇内容, 共 266.0 次阅读, 收获喜欢 8 次。

关注

评论

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

利用淘宝商品评论API返回值优化商品转化率:策略与实践

代码忍者

智能引领,服务升级:哈银消费金融以科技力量重塑金融服务体验

极客天地

黑神话悟空-快速部署

京东科技开发者

mac强大的安卓文件传输工具:Android File Transfer for mac 版

你的猪会飞吗

Mac软件 Android File Transfer mac破解软件下载

日常工作中需要避免的9个React坏习惯

不在线第一只蜗牛

JavaScript 前端 React

如何设计真正的实时数据湖?

tapdata

实时数据湖 数据集处理流程 湖仓一体是什么

Oracle数据库客户端 SQLPro for Oracle for mac v1.0.302激活版

Rose

【我在京东做产研】校招 2 年,个人角度(成长)回顾 - 行且知

京东科技开发者

解析阿里巴巴中国站商品详情API返回值的更新与变化

技术冰糖葫芦

API Explorer API 测试 pinduoduo API

亲测兼容M1 PS2019 for mac中文直装版 附Photoshop2019破解补丁

Rose

网易伏羲AI Agent 技术分享:揭秘AOP框架在《永劫无间》手游Copilot的应用实践

网易伏羲

aop agent 网易伏羲 Copilot 游戏AI

MySQL中为什么要使用索引合并(Index Merge)?

不在线第一只蜗牛

MySQL 数据库 索引

SD-WAN组网对比传统组网有哪些优点?

Ogcloud

SD-WAN 企业组网 SD-WAN组网 SD-WAN服务商 SDWAN

淘宝 API 接口的实际应用案例

Noah

百度搜索的RLHF性能优化实践

百度Geek说

百度 算法 性能优化

mysql磁盘碎片整理

京东科技开发者

TapData 信创数据源 | 国产信创数据库 Vastbase 数据同步指南,加速国产化进程,推进自主创新建设

tapdata

数据同步

浅析JVM invokedynamic指令和Java Lambda语法|得物技术

得物技术

Java JVM 企业号2024年8月PK榜

京东商品详情数据接口解析(实时数据含测试及示例)

tbapi

京东API接口 京东商品详情接口 京东商品数据采集

Rectangle Pro for Mac v3.0.31激活版 窗口管理布局工具

Rose

TikTok直播网络加速方法

Ogcloud

TikTok tiktok运营 tiktok直播 tiktok直播专线 tiktok矩阵

Google正制订一项新协议,旨在替换掉HTTP_Google_Abel Avram_InfoQ精选文章