OceaBase开发者大会落地上海!4月20日共同探索数据库前沿趋势!报名戳 了解详情
写点什么

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:262684
用户头像

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

关注

评论

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

2022-07微软漏洞通告

火绒安全

microsoft 安全 漏洞

还不了解进程吗?就这一篇!

C++后台开发

网络编程 进程 通信 linux开发 C++开发

Java 集合

Damon

7月月更

Kubernetes入坑篇

青柚1943

Kubernetes DevOps minikube

不要小看WebSocket!长连接、有状态、双向、全双工都是王炸技能

wljslmz

HTTP websocket 7月月更

从全球价值链视角看,京东云数智供应链对未来经济有何影响?

脑极体

Python图像处理丨图像腐蚀与图像膨胀

华为云开发者联盟

Python 软件 开发 图像处理

我用开天平台做了一个城市防疫政策查询系统,你不试试?

华为云开发者联盟

开发 华为云 开天aPaaS 开天 城市防疫政策

在线多行文本批量正则替换添加后缀工具

入门小站

工具

融云 x 天聊,用声音打造「无压力社交」栖息地

融云 RongCloud

ArkUI路由跳转概览

坚果

HarmonyOS OpenHarmony 7月月更

Chrome实现自动化测试:录制回放网页动作

和牛

测试

《Linux设备驱动开发详解》读书笔记

贾献华

7月月更

Python|制作词云,改变词云字体颜色

AXYZdong

Python 7月月更

日志黑名单,真的能帮你省钱!

观测云

转行前端是自学好还是培训班好

小谷哥

拔掉电源会怎样?GaussDB(for Redis)双活让你有备无患

华为云开发者联盟

数据库 后端

如何系统学习web前端技术知识

小谷哥

Web安全之Java反序列漏洞总结

网络安全学海

网络安全 安全 信息安全 渗透测试 漏洞挖掘

StarRocks 成都见!企业如何打造极速统一的数据分析新范式,助力业务全方位升级

StarRocks

数据库 大数据 数据分析 国产数据库

本周四晚19:00知识赋能第3期直播丨OpenHarmony智能家居项目之控制面板功能实现

OpenHarmony开发者

Open Harmony

小程序容器技术让混合App开发效率提升

Geek_99967b

小程序容器

泰凌微电子B91通用开发板合入OpenHarmony社区主干

科技汇

C 语言入门(四)

逝缘~

7月月更

2022冲刺金九银十震撼发布!Java八股文+大厂面试真题,干货满满!

了不起的程序猿

Java java程序员 java面试

AIOps落地五大原则(三):架构路线

BizSeer必示科技

人工智能 AIOPS

Python3详细的数组基础操作-入门必备[列表的操作]

迷彩

数组 Python基础 列表 7月月更

新书上市 | C 语言经典教材配套“习题解答”,原书累计印数 10 万 +

图灵教育

C语言

开鸿智谷 Niobe 407 正式并入OpenHarmony代码主干

科技汇

ECCV2022 | 腾讯优图29篇论文入选,含人脸安全、图像分割、目标检测等多个研究方向

科技热闻

在线SQL转XML工具

入门小站

工具

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