SPDY 协议简介及如何编译含有 SPDY 的 NGINX

本贴最后更新于 3723 天前,其中的信息可能已经斗转星移

SPDY 是 Google 开发的基于传输控制协议(TCP)的应用层协议 (发音同“speedy”),以最小化网络延迟,提升网络速度,优化用户的网络使用体验。SPDY 并不是一种用于替代 HTTP 的协议,而是对 HTTP 协议 的增强。新协议的功能包括数据流的多路复用、请求优先级,以及 HTTP 包头压缩。谷歌表示,引入 SPDY 协议后,在实验室测试中页面加载速度比原先快 64%。

目前主流浏览器 Google Chrome Mozilla Firefox Opera Internet Explorer 都已经支持了 SPDY,主流 web 服务器 Apache、Nginx、Netty、Jetty、node.js 等都已经开始初步的支持 SPDY 基本已经支持 SPDY,SPDY 当前并不是一个标准协议,但 SPDY 的开发组已经开始推动 SPDY 成为正式标准。

本文主要了解 SPDY 的基本概念,以及如何编译一个含有 SPDY 的 nginx。

HTTP 协议存性能上的一些问题

一个连接一个请求。浏览器和 web server 之间都是以短连接方式交互,一个连接只服务一次请求,对于一个需要加载多个资源的页面来说,将会带来很高的延迟。

只能由客户端发起请求。服务器不能主动的将一些必须的资源推送给客户端。

HTTP 协议只能对 body 进行压缩处理,不能压缩 header。在一个 cookie 较多的站点,将对带宽造成严重的浪费。

冗余的头部。一些头部在同一个通道中通过请求在重复的发送。像 User-Agent Host Accept* 常常是固定不变的,所以不需要重复发送

可选的压缩。HTTP 使用可选的压缩编码。但是内容应该总是使用压缩格式。

SPDY 的目标

1.SPDY 为 WEB 定义和实现了一个应用层的协议来大大降低延迟。SPDY 的高层次目标是:

2.减少 50% 的网页加载时间。我们的成果已经初步接近这个目标(见下面解释)。

3.最小化部署复杂性。SPDY 使用 TCP 作为相关的传输层,所以现存的网络基础设施,不需要改变。

4.避免网站开发者需要对网站作出任何改变。支持 SPDY 唯一需要的改变在用户 user agent 和 web server。

5.聚集有兴趣探索协议来解决延迟问题的志同道合的开发者。我们希望和开源社区 行业专家一起来开发这个新的协议。

一些具体的技术目标:

1.单个 tcp 连接支持并发的 HTTP 请求

2.压缩头部和去掉不必要的头部,来减少当前 HTTP 使用的带宽

3.定义一个容易实现,在服务器端高效率的协议。我们希望通过减少边缘情况 定义易解析的消息格式来减少 HTTP 的复杂性

4.让 SSL 协议在现存的网络基础设施下有更好的安全性和兼容性。虽然 SSL 确实引入了延迟,我们认为网络的长远发展依赖一个安全的网络连接。另外,使用 SSL 来确保整个通信不中断是必要的。

SPDY 设计和特征

在 SSL 层上加了一个 SPDY session 层,来实现并发和 stream 机制。

通常的 HTTP GET 和 POST 格式仍然是一样的;然而 SPDY 为编码和传输设计了一个新的帧格式。

基本特征

复用流 SPDY 允许在一个连接上无限制的并发流。因为请求在一个通道上,TCP 效率更高:更少的网络连接,更少更密集的数据包被发出

请求优先级 虽然无数的并行数据流解决了序列化问题,但他们引入了另外的问题

HTTP 头部压缩

高级特征

此外,SPDY 提供了高级特征,服务器启动流。服务器启动流能用来分发内容到客户端,而不需要客户端请求它。这个选项可以由 web 开发人员通过如下两种方法配置:

Server push SPDY 通过 X-Associated-Content 头试验了服务器推送数据给客户端的选项。这个头告诉客户端服务器将在客户端请求资源之前,推送资源给它。对于初始页面下载(例如用户初次访问这个网站),这样能大大提升用户体验

Server hint 相对于自动的推送资源到客户端,服务器使用 X-Subresources 头去建议客户端,来请求特殊的资源,这是在服务器事先知道客户的这些资源将被需要 的情况下。但是,服务器仍然在发送内容前等待客户请求。通过慢速链接,这个选项能减少一个客户端发现它需要的资源数百毫秒的时间,并可能对非初始页面加载 会更好。

SPDY 实现

下面是已经实现的:

一个能同时提供 HTTP SPDY 服务的高速 全内存的服务程序。我们将在不久的将来开源这些代码

一个能使用 HTTP 或者 SPDY 的 chrome 浏览器。

一个测试和基准设施,来确保页面是不变的。

NGINX SPDY 编译

http://nginx.org/patches/attic/spdy/README.txt

Nginx 支持 SPDY draft 2

Nginx 从 1.3.15 开始支持

需要 OpenSSL 1.01+

目前已知的问题和限制:

不支持 server push

不支持 SPDY 连接速率限制

如何编译含 SPDY 的 nginx?

1.安装 OpenSSL 1.0.1+

2.下载 nginx 1.3.x 以上的版本

3.解压 nginx

4.下载应用 SPDY module patch

wget http://nginx.org/patches/spdy/patch.spdy.txt

patch -p1 < patch.spdy.txt

5.配置

./configure --with-http_ssl_module --with-http_spdy_module

6.编译

Make

配置

server {
    listen 443 ssl spdy default_server;
    ssl_certificate server.crt;
    ssl_certificate_key server.key;
    ...
}

下一步会主要学习 SPDY 草案的内容,以及阅读代码。

转自链接:http://network.51cto.com/art/201401/426957.htm

【编辑推荐】

Facebook 宣布支持谷歌 SPDY 协议:欲取代 HTTP

为高负载网络优化 Nginx 和 Node.js 方法

HTTP 代理与 SPDY 协议

手动同步自: http://vanessa.b3log.org/SPDY-Nginx

  • Browser
    1 引用
  • 性能
    62 引用 • 180 回帖
  • NGINX

    NGINX 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 NGINX 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。

    311 引用 • 546 回帖 • 37 关注
  • SPDY
    1 引用

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
Vanessa
我们终此一生,就是要摆脱他人的期待,找到真正的自己。

推荐标签 标签

  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    116 引用 • 99 回帖 • 266 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    228 引用 • 1450 回帖
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    172 引用 • 990 回帖
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    51 引用 • 37 回帖
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 692 关注
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    148 引用 • 257 回帖 • 1 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    11 引用 • 5 回帖 • 563 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1347 回帖 • 1 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    108 引用 • 54 回帖
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 250 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    284 引用 • 4481 回帖 • 656 关注
  • OnlyOffice
    4 引用 • 28 关注
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    124 引用 • 580 回帖
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1083 引用 • 3461 回帖 • 287 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    15 引用 • 7 回帖 • 9 关注
  • ActiveMQ

    ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

    19 引用 • 13 回帖 • 628 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    75 引用 • 145 回帖
  • 笔记

    好记性不如烂笔头。

    303 引用 • 777 回帖
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    535 引用 • 672 回帖 • 2 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 398 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    25 引用 • 191 回帖 • 19 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    28 引用 • 108 回帖 • 3 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    14 引用 • 7 回帖 • 1 关注
  • 分享

    有什么新发现就分享给大家吧!

    242 引用 • 1746 回帖 • 1 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    324 引用 • 1395 回帖 • 3 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖 • 5 关注