写点什么

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

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

关注

评论

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

源码分析 | Mybatis接口没有实现类为什么可以执行增删改查

小傅哥

Java 源码分析 小傅哥 mybatis 编程思维

100天从 Python 小白到大神最良心的学习资源!

JackTian

Python GitHub 学习 Python-100-Days Python-Core-50-Courses

揭秘神经拟态计算:缘何成为AI界新宠?

最新动态

栀子花,我们应该像你一样静静绽放

小天同学

个人感想 感悟 日常思考

软件开发生产率改进之我见(二)

清水

软件工程 软件开发 技术管理

python实现·十大排序算法之计数排序(Counting Sort)

南风以南

Python 排序算法 计数排序

健身一周年:持续锻炼带来无法想象的改变

小鲸数据

学习 职业 专注 健身

实现元素等高: Flexbox vs. Grid

寇云

CSS css3

数据与广告系列三:合约广告与与衍生的第三方广告数据监控

黄崇远@数据虫巢

数据挖掘 互联网 广告 移动互联网

点击劫持:无X-Frame-Options头信息(修复)

唯爱

redis过期策略和内存淘汰机制

wjchenge

Android原生人脸识别Camera2+FaceDetector 快速实现人脸跟踪

sar

你为什么“啃不动”你手中的技术书?

图灵社区

Java Python 算法 HTTP R语言

码农远程办公指北

大伟

宕机原因千千万,被雷劈了最无奈

田晓旭

你的团队是干什么的?

姜戈

团队管理 团队职能

多线程与线程安全(实例讲解)

YoungZY

Java 多线程 线程安全

好的软件工程原则

pydata

ARTS week 2

锈蠢刀

管理规划篇

姜戈

团队管理 团队组织

联邦学习与推荐系统

博文视点Broadview

人工智能 大数据 学习 推荐系统

一致性算法 Raft 简述

架构精进之路

raft 一致性算法

Vol.1 Java初探,新手必看!

pyfn2030

编程 新手指南

终于,我也到了和Eclipse说再见的时候,难说再见

程序员小跃

Java eclipse IDEA

Spring Security 两种资源放行策略,千万别用错了!

江南一点雨

Java spring springboot springsecurity

使用<input>标签实现六个格子验证码输入框

码上生长

Java vue.js 大前端

你的团队想做出什么成果?

姜戈

团队管理

突破困局

Neco.W

感悟 工作 创业心态

提升输入效率第一步——切换双拼

dongh11

效率工具 提升效率 生产力 分享 有趣

假如孔乙己是程序员

顿晓

学习 程序员 孔乙己

你真的会用Mac中的Finder吗

Winann

macos 效率 App Mac

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