`
Josh_Persistence
  • 浏览: 1651431 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类

SPDY:Google开发的下一代HTTP协议

阅读更多

SPDY(发音同"speedy"):Google开发的下一代HTTP协议

(解决HTTP协议的缺点,Wrapper模式)

概述

SPDY是Google宣布正在开发的下一代网络协议,SPDY并不是一种用于替代HTTP的协议,而是对HTTP协议的增强。HTTP自上世纪90年代问世以来,已有二十年的历史,期间互联网本身发生了很大的变化,也使得HTTP的许多不足暴露了出来,现在它已经不能满足许多web app的要求。Google表示,引入SPDY协议后,在实验室测试中页面加载速度比原先快64%,并且目前已经在Gmail等应用中使用。目前业界支持SPDY的服务器有NettyNginx(将要支持)。Nginx 官方发布下一个版本 1.3.0 的路线图,该版本将支持 Google SPDY



 

Google之所以要改动HTTP协议而不是TCP/IP,是因为改变HTTP只需更新Browser和web server就行了,而改动TCP/IP就困难多了,牵扯面太广,需要更新巨量的路由器,服务器和客户端的操作系统。

SPDY的设计特点

SPDY的设计特点是在SSL层的基础上,增加了一个session 层,从而在一个tcp 连接基础上,实现了多并发和交叉流传输。HTTP 的GET ,POST 仍旧采用旧有的消息格式,当然SPDY 协议对原有的数据做了封装和编码,这里采用Wrapper设计模式。



 SPDY的目标就是通过其基本特性和高级特性,来达到低访问延迟。

SPDY的特性

1、流复用

SPDY最牛逼的地方,是允许在一个TCP连接里面,允许无限并发流(在双方资源可承受的情况下)。因为请求是在一个单一的通道交错传输,TCP可以达到很高的效率,从而减少网络连接需要,可以以很高的数据密度做传输。

 

2、优先级:(因为支持并行,所以必须要有优先级机制)

虽然无限的并行数据流解决了序列化问题,但是它们引入了另一个问题:如果由于信道带宽的限制,客户端可能会阻止怕堵塞通道的要求。为了克服这个问题,SPDY实现请求的优先次序:客户端可以请求尽可能多的项目,每个请求分配一个优先级。这样 即使高优先级的请求仍处在pending状态,通道也不会传输非关键的,低优先级的请求,这样就有效地阻止了传输拥塞。

 

3、Http header压缩

对于HTTP 请求,响应头,SPDY都做了压缩,这样包更小,对于RESTFUL类型的WEB2.0 ,or OpenAPI 业务,将会有可观的效率提升。

 

4、服务器端推送

SPDY通过X-Associated-Content 协议头来向客户端推送数据。通知客户端,我要向你推送资源,准备接收好了。最近火爆的Google+ ,如果你用chrome浏览器,默认就采用SPDY技术,并且开启了服务器推送技术。服务器的推技术,全面提升了用户体验,使G+ 产品很快占据了足够多的优势,最近Facebook 开发自己的浏览器,也有摆脱现在技术限制的考虑。

 

5、Server hint

不像上面提到的PUSH 技术,服务器会先告诉浏览器,你可以下载ABC资源了,这个ABC资源,可能就是下一个页面的JS ,CSS ,或者内容。服务器不会主动推送的,仍旧等待客户端请求,这对于低速网络,是个很大的优化,有点类似于我们的预加载技术。

 

6、安全防攻击

这点在官网上没有介绍到,但由于SPDY采用了SSL+数据压缩,安全性上有了很大提升。尤其很多国家的网络审查将很难使用。这是否会成为SPDY发展的一个限制呢?

 

工作机制

从SPDY协议的设计角度来看,它在HTTP和SSL层之间增加了一个SPDY会话层,原有的GET和POST请求的格式都不变,SPDY会话层会把请求封装成一个SPDY frame(SPDY帧),然后把SPDY帧丢给ssl层或者tcp层发送,这样做一方面是为了尽量兼容现有的HTTP协议,另一方面也主要是让SPDY协议易于部署,对应用层来说是透明的。

 

在SPDY协议中有几个概念是比较重要的:

1、session--会话,一个SPDY会话实质上就是一个tcp连接。
2、stream--虚拟流,一个SPDY会话可以拥有多条虚拟流,每条流都有标识其身份的流ID,所有的请求和应答都是通过流进行的
3、frame--SPDY帧,在SPDY协议中,客户端和服务器交互的数据就是SPDY帧,SPDY帧可以分为控制帧和数据帧,数据帧和控制帧通过帧的第一个比特位进行区分,帧的具体结构这里就不分析了,有兴趣的可以去查看google发布的SPDY草案。

 

        首先来看下SPDY协议中的http请求和应答格式,为了与当前的web应用尽可能的兼容,SPDY协议基本上保留了http请求头和响应头语义,主要的变化有以下几点:
1、请求和应答头中的connection和keep-alive不再有效,即使存在也会被忽略,host头也会被忽略
2、默认并且强制使用gzip压缩
3、http请求和应答报头都将被压缩

        当用户请求打开一个网页,SPDY会话层会向web服务器发起一个tcp连接,(在spdy协议中所有的tcp连接都是长连接,客户端一般不会断开连接,除非用户离开当前页面,跳向另一个页面,连接的断开由服务器负责, 服务器会关掉那些长时间处于空闲的连接),建立tcp连接后,客户端和服务器就会开始进行帧的交互。



 

       首先客户端为了发送http请求,需要与服务端建立虚拟流连接,建立流连接的过程和tcp建立连接的过程很相似,如上图所示,客户端发送SYN_STREAM控制帧,控制帧中可以包含流优先级,高优先级流中的请求将会被服务器优先处理,服务器收到SYN_STREAM帧后将回复SYN_REPLY帧表示连接建立,这里要注意的是,客户端不需要等待SYN_REPLY帧,就可以直接在该条流上发送数据帧。当连接建立后,双方就可以在流上发送数据了。当一方发送数据完毕后,就可以发送一个带有FIN_FLAG标志的帧,表示不会在该流上发送数据,流连接处于半关闭状态,如果双方都处于半关闭状态时,流就会被认为结束了,另外有个FIN_STREAM控制帧用于主动或者异常情况下结束流的传输。

 

与http协议相比

HTTP 1.1协议的不足:

1、一个连接同时只能处理一个请求。

也就是说,一个HTTP连接一次只能请求一个资源,即使是长连接,下 一个资源的请求也只能等到上一个请求完成后才能执行,服务器的端到端延迟使得tcp的重用率很低。为了提高网页加载速度,浏览器则通过建立多条连接来同时请求多个资源,(当前浏览器设置每个域的连接数为6个),这会带来一定的开销,而且请求的连接数也是有限的。

2、HTTP请求和响应头未压缩

随着互联网应用越来越多的使用cookie和useragents等扩展特性,当前HTTP的请求和响应头越来越大,请求头部大小达到700-800bytes已经很常见了,甚至还有达到2kb的,对于低带宽的网络,这会带来很大的延迟,减小头部的大小可以有效的降低数据传输延迟。

3、HTTP冗余头部

有些HTTP头比如User-Agent,Host和Accept等会重复的发送,这些字段基本上是不变的,没有必要进行重复发送。

4、只有客户端才能发送请求

在现在的HTTP协议中,只有客户端才能主动的发起请求,服务器端即使知道客户端需要哪些资源,它也不能主动的发送,只能等待客户端发起对该资源的请求。

 

     SPDY协议认为以上不足严重影响了网页的下载速度,针对这些不足的地方SPDY协议主要进行了以下四个方面的改进(即四个特性):

 

1、在一个SPDY连接中允许建立多条stream(虚拟流),并发发送多个HTTP请求,请求个数是没有限制的,这里涉及到连接中虚拟流的概念。

2、HTTP请求可以具有优先级,也就是说客户端可以要求服务器优先发送重要的资源,这就避免了一个处理时间很长的非关键请求阻塞了服务器对后面请求的处理,影响网页的加载速度。

3、SPDY协议允许压缩头部,减小HTTP头部的大小,减小对带宽的占用。

4、服务器可以主动的给客户端发送数据,不需要客户端的主动请求

 

 

  • 大小: 58.4 KB
  • 大小: 13.7 KB
  • 大小: 19.9 KB
1
1
分享到:
评论
6 楼 Josh_Persistence 2015-04-10  
yvfish 写道
谷歌已经放弃了

http2.0采用了spdy的很多思想和技术。
5 楼 Josh_Persistence 2015-04-10  
philhong 写道
已经放弃了,请戳 http://www.cnbeta.com/articles/369575.htm

http2.0采用了spdy的很多思想和技术。
4 楼 Josh_Persistence 2015-04-10  
yvfish 写道
谷歌已经放弃了

Http2.0采用了spdy.
3 楼 Josh_Persistence 2015-04-10  
yvfish 写道
谷歌已经放弃了

Http2.0采用了spdy.
2 楼 philhong 2015-04-10  
已经放弃了,请戳 http://www.cnbeta.com/articles/369575.htm
1 楼 yvfish 2015-04-10  
谷歌已经放弃了

相关推荐

    SPDY协议文档 (英文)

    SPDY(读作“speedy”)是一种由Google设计并开发的网络传输协议,旨在为万维网上的内容提供低延迟的传输服务。该协议的设计目的是减少网页加载时间,并提高用户体验。SPDY通过引入两个层次的协议来实现这一目标:...

    SPDY

    SPDY(发音为 "speedy")是一种由Google开发的网络协议,旨在减少网页加载时间,提高用户在浏览网页时的性能体验。这个协议是在HTTP/1.1的基础上设计的,目标是解决HTTP/1.1存在的若干效率问题,如头部冗余、请求...

    SPDY英文文档(HTTP2基础)

    SPDY(Speedy)是Google开发的一种网络协议,它的目标是优化HTTP协议,减少网页的加载时间并提高网络通信的安全性。在HTTP2被广泛采用之前,SPDY被视为一种潜在的替代方案,它引入了两个关键特性:多路复用和压缩,...

    node-spdy:Node.js上的SPDY服务器

    适用于node.js的SPDY服务器 使用此模块,您可以在具有自然http模块界面并回退到常规https的node.js中创建 / 服务器(对于既不支持HTTP2也不支持SPDY的浏览器)。 这个模块命名spdy但它两个HTTP / 2(H 2)和SPDY(2,...

    HTTP SPDY客户端开发包okhttp.zip

    okhttp 是一个 Java 的 HTTP SPDY 客户端开发包,同时也支持 Android。 示例代码: OkHttpClient client = new OkHttpClient(); String get(URL url) throws IOException { HttpURLConnection connection = ...

    spdy:图片描述系统评分

    标题中的"spdy"可能是指"SPDY"协议,它是一种由Google开发的网络协议,旨在提高网页加载速度,但请注意,这里的上下文似乎与原始的SPDY协议无关,更像是一个项目的代号或者命名习惯。描述提到的是一个“图片描述系统...

    第十二章:SPDY.pdf

    SPDY(发音同“Speedy”)是由Google开发的一种基于传输控制协议(TCP)的应用层协议,旨在优化互联网上的网页加载速度和提高安全性。SPDY的目标是通过压缩、多路复用和优先级调度来减少延迟,从而加快网页的加载时间...

    spdy:golang.orgxnetspdy 的副本

    这是曾经在 golang.org/x/net/spdy 上可用... 当 Chromium 浏览器放弃 spdy 支持时,我们也会从 nghttp2 中放弃 spdy 支持,并删除此存储库。 由于我们无意维护此存储库,因此会默默忽略针对此存储库的任何 PR 和问题。

    jschan-spdy:jschan的SPDY传输

    在标准SPDY传输上使用时,jschan与当前的Go参考实现兼容。 我们还有一个websocket传输机制,允许我们在浏览器上运行jschan。 规范未涵盖此功能,并且与其他实现不兼容。 安装 npm install jschan-spdy --save 例子...

    Node.js-spdy-node.js中的SPDY服务器

    而SPDY(发音为 "speedy")是Google提出的一种网络协议,旨在提高网页加载速度,减少延迟,优化用户体验。它在HTTP的基础上进行了改进,尤其是对多路复用的支持,减少了TCP连接的数量。 **SPDY协议的特性** 1. **多...

    js-libp2p-spdy:与libp2p Stream Muxer预期接口兼容的SPDY 3.1实现包装器

    js-libp2p-spdy 与libp2p Stream Muxer预期接口兼容的SPDY 3.1实现包装器首席维护者安装npm > npm i libp2p-spdy在Node.js中使用const spdy = require ( 'libp2p-spdy' ) 在带有browserify,webpack或任何其他捆绑...

    Chrome插件HTTP/2 and SPDY indicator

    Chrome插件HTTP/2 and SPDY indicator,安装完毕后访问启用HTTP2的站点,如果地址栏出现蓝色的闪电,说明站点已启用HTTP2.0

    SPDY for iPhone.zip

    SPDY (Speedy) 是一种由 Google 开发的网络协议,旨在提高网页加载速度,降低延迟,优化用户在互联网上的体验。它通过压缩头部信息、多路复用连接以及优先级排序等技术,显著提高了HTTP协议的效率。对于iPhone应用...

    mod-spdy-beta_current_i386.rpm

    SPDY并不是一种用于替代HTTP的协议,而是对HTTP协议的增强。新协议的功能包括数据流的多路复用、请求优先级...谷歌已经开发一个网络服务器原型机,以及支持SPDY协议的Chrome浏览器版本。 该文件是apache支持SPDY的扩展

    spedye: A reverse proxy for the HTTPS and SPDY protocols

    而"SPDY"(Speedy)是由Google开发的一种网络传输协议,旨在提高网页加载速度,通过减少延迟和优化HTTP协议来改善用户体验。"HTTPS"则是HTTP协议的安全版本,通过SSL/TLS协议提供数据加密、服务器身份验证和消息完整...

    http协议开发包

    这个"HTTP协议开发包"很可能包含了用于处理HTTP请求和响应的Java库,这些库可以帮助开发者更方便地构建和解析HTTP消息。通常,这些jar文件可能包括以下组件: 1. **Apache HttpClient**:这是一个强大的Java HTTP...

    前端开源库-spdy-keys

    SPDY是由Google开发的一种网络传输协议,旨在优化网页加载速度,减少延迟,并提高用户访问网站的安全性。它在HTTP/2之前被广泛使用,为HTTP提供了一种更高效的替代方案。 首先,让我们详细了解一下SPDY协议。SPDY的...

    加速Web传输:Linux中SPDY/HTTP2的深度优化实践

    Linux是一种开源的、基于Unix的操作系统内核,由林纳斯·托瓦兹(Linus Torvalds)于1991年首次发布。...7. **广泛的软件支持**:Linux拥有丰富的软件库,包括服务器软件、图形界面、办公软件、开发工具

    前端开源库-spdy-push

    SPDY(发音为 "speedy")是Google提出的一种网络传输协议,设计目标是优化网页加载速度,减少页面渲染时间。SPDY在HTTP/1.1的基础上进行了改进,引入了多路复用、优先级排序、头部压缩等特性,其中SPDY Push技术是其...

Global site tag (gtag.js) - Google Analytics