自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SPDY協(xié)議簡介及如何編譯含有SPDY的nginx

網(wǎng)絡(luò) 路由交換
SPDY是Google開發(fā)的基于傳輸控制協(xié)議(TCP)的應(yīng)用層協(xié)議 (發(fā)音同“speedy”),以最小化網(wǎng)絡(luò)延遲,提升網(wǎng)絡(luò)速度,優(yōu)化用戶的網(wǎng)絡(luò)使用體驗。本文主要了解SPDY的基本概念,以及如何編譯一個含有SPDY的nginx。

SPDY是Google開發(fā)的基于傳輸控制協(xié)議(TCP)的應(yīng)用層協(xié)議 (發(fā)音同“speedy”),以最小化網(wǎng)絡(luò)延遲,提升網(wǎng)絡(luò)速度,優(yōu)化用戶的網(wǎng)絡(luò)使用體驗。SPDY并不是一種用于替代HTTP的協(xié)議,而是對HTTP協(xié)議的增強。新協(xié)議的功能包括數(shù)據(jù)流的多路復(fù)用、請求優(yōu)先級,以及HTTP包頭壓縮。谷歌表示,引入SPDY協(xié)議后,在實驗室測試中頁面加載速度比原先快64%。

目前主流瀏覽器Google Chrome Mozilla Firefox Opera Internet Explorer都已經(jīng)支持了SPDY,主流web服務(wù)器Apache、Nginx、Netty、Jetty、node.js等都已經(jīng)開始初步的支持SPDY基本已經(jīng)支持SPDY,SPDY當(dāng)前并不是一個標(biāo)準(zhǔn)協(xié)議,但SPDY的開發(fā)組已經(jīng)開始推動SPDY成為正式標(biāo)準(zhǔn)。

本文主要了解SPDY的基本概念,以及如何編譯一個含有SPDY的nginx。

HTTP協(xié)議存性能上的一些問題

一個連接一個請求。瀏覽器和web server之間都是以短連接方式交互,一個連接只服務(wù)一次請求,對于一個需要加載多個資源的頁面來說,將會帶來很高的延遲。

只能由客戶端發(fā)起請求。服務(wù)器不能主動的將一些必須的資源推送給客戶端。

HTTP協(xié)議只能對body進行壓縮處理,不能壓縮header。在一個cookie較多的站點,將對帶寬造成嚴重的浪費。

冗余的頭部。一些頭部在同一個通道中通過請求在重復(fù)的發(fā)送。像User-Agent Host Accept* 常常是固定不變的,所以不需要重復(fù)發(fā)送

可選的壓縮。HTTP 使用可選的壓縮編碼。但是內(nèi)容應(yīng)該總是使用壓縮格式。

SPDY的目標(biāo)

1.SPDY為WEB定義和實現(xiàn)了一個應(yīng)用層的協(xié)議來大大降低延遲。SPDY的高層次目標(biāo)是:

2.減少50%的網(wǎng)頁加載時間。我們的成果已經(jīng)初步接近這個目標(biāo)(見下面解釋)。

3.最小化部署復(fù)雜性。SPDY使用TCP作為相關(guān)的傳輸層,所以現(xiàn)存的網(wǎng)絡(luò)基礎(chǔ)設(shè)施,不需要改變。

4.避免網(wǎng)站開發(fā)者需要對網(wǎng)站作出任何改變。支持SPDY***需要的改變在用戶user agent和web server。

5.聚集有興趣探索協(xié)議來解決延遲問題的志同道合的開發(fā)者。我們希望和開源社區(qū) 行業(yè)專家一起來開發(fā)這個新的協(xié)議。

一些具體的技術(shù)目標(biāo):

1.單個tcp連接支持并發(fā)的HTTP請求

2.壓縮頭部和去掉不必要的頭部,來減少當(dāng)前HTTP使用的帶寬

3.定義一個容易實現(xiàn),在服務(wù)器端高效率的協(xié)議。我們希望通過減少邊緣情況 定義易解析的消息格式來減少HTTP的復(fù)雜性

4.讓SSL協(xié)議在現(xiàn)存的網(wǎng)絡(luò)基礎(chǔ)設(shè)施下有更好的安全性和兼容性。雖然SSL確實引入了延遲,我們認為網(wǎng)絡(luò)的長遠發(fā)展依賴一個安全的網(wǎng)絡(luò)連接。另外,使用SSL來確保整個通信不中斷是必要的。

SPDY設(shè)計和特征

在SSL層上加了一個SPDY session層,來實現(xiàn)并發(fā)和stream機制。

通常的HTTP GET和POST格式仍然是一樣的;然而SPDY為編碼和傳輸設(shè)計了一個新的幀格式。

基本特征

復(fù)用流 SPDY允許在一個連接上無限制的并發(fā)流。因為請求在一個通道上,TCP效率更高:更少的網(wǎng)絡(luò)連接,更少更密集的數(shù)據(jù)包被發(fā)出

請求優(yōu)先級 雖然無數(shù)的并行數(shù)據(jù)流解決了序列化問題,但他們引入了另外的問題

HTTP頭部壓縮

高級特征

此外,SPDY提供了高級特征,服務(wù)器啟動流。服務(wù)器啟動流能用來分發(fā)內(nèi)容到客戶端,而不需要客戶端請求它。這個選項可以由web開發(fā)人員通過如下兩種方法配置:

Server push SPDY通過X-Associated-Content頭試驗了服務(wù)器推送數(shù)據(jù)給客戶端的選項。這個頭告訴客戶端服務(wù)器將在客戶端請求資源之前,推送資源給它。對于初始頁面下載(例如用戶初次訪問這個網(wǎng)站),這樣能大大提升用戶體驗

Server hint 相對于自動的推送資源到客戶端,服務(wù)器使用X-Subresources頭去建議客戶端,來請求特殊的資源,這是在服務(wù)器事先知道客戶的這些資源將被需要的情況下。但是,服務(wù)器仍然在發(fā)送內(nèi)容前等待客戶請求。通過慢速鏈接,這個選項能減少一個客戶端發(fā)現(xiàn)它需要的資源數(shù)百毫秒的時間,并可能對非初始頁面加載會更好。

SPDY實現(xiàn)

下面是已經(jīng)實現(xiàn)的:

一個能同時提供HTTP SPDY服務(wù)的高速 全內(nèi)存的服務(wù)程序。我們將在不久的將來開源這些代碼

一個能使用HTTP或者SPDY的chrome瀏覽器。

一個測試和基準(zhǔn)設(shè)施,來確保頁面是不變的。

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.下載應(yīng)用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;

...

}

下一步會主要學(xué)習(xí)SPDY草案的內(nèi)容,以及閱讀代碼。

原文鏈接:http://blog.csdn.net/liujiyong7/article/details/17953979

責(zé)任編輯:林琳 來源: 博客
相關(guān)推薦

2013-07-09 14:36:24

2015-09-29 14:01:45

SPDY網(wǎng)絡(luò)協(xié)議響應(yīng)頭網(wǎng)絡(luò)協(xié)議

2012-07-16 09:58:15

SPDY協(xié)議HTTP

2011-04-12 10:00:41

SPDYSPDY協(xié)議

2012-03-21 12:57:29

JavaJettyServlet

2013-06-26 13:25:43

IE11瀏覽器

2015-02-05 09:25:51

HTTPSSPDYHTTP2

2016-11-08 09:04:20

ChromeHTTP網(wǎng)站

2015-02-13 10:34:28

HTTP.2GoogleSPDY

2012-05-09 09:25:56

F5SPDY網(wǎng)關(guān)

2019-04-22 11:38:00

HTTPHTTP2.0HTTPS

2015-09-15 10:40:26

HTTP2 WEB 性能優(yōu)化

2012-05-03 15:14:38

Firefox 13Beta

2018-11-14 15:00:08

HTTP程序員前端

2013-08-23 10:11:01

生成樹協(xié)議交換技術(shù)生成樹

2020-08-26 07:50:01

HTTP 3網(wǎng)絡(luò)協(xié)議HTTP

2010-07-06 16:02:30

HART協(xié)議

2011-11-08 21:24:30

SNMP

2010-09-27 14:10:29

DNS協(xié)議簡介

2023-10-27 08:58:02

點贊
收藏

51CTO技術(shù)棧公眾號