《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 業界動態 > 為什么我們需要HTTP/2?

為什么我們需要HTTP/2?

2015-03-20

       HTTP 1.0/1.1是最為人所知的網際網路通訊協定,然而,該標準最后一次修訂是在十幾年前,面對當前龐大的網頁應用需求,它有那些不合時宜的地方呢?

   WWW 的運作,基本上,是倚靠名為HTTP(HyperText Transfer Protocol)的通訊協定,此協定的第一版為 HTTP/1.0,但在 1999 年做了一些改進之后,制定該協定規格的 IETF,將此改版命名為HTTP/1.1。而1999年問世的HTTP /1.1協定,可以說是主宰了整個Internet的流量至今,而且,成為了 Internet 最重要的應用層通訊協定之一。

  但即使 HTTP有著如此的重要性,而且伴隨著Web 的應用持續不斷的壯大,幾乎可以說它就是 Internet 的主角了,但是它本身并非毫無缺點,事實上它 的缺點還挺明顯的。HTTP就跟許多取得主宰性地位的協定一樣,其之所以能取得支配性的地位,不在其協定本身設計之優勢,而是有著其他的時空因素。 HTTP簡單易用、伴隨著Web的快速成長而成長,最終得到了今天的地位。

  但這組沿用許久未改版的協定,也因為網路生態的改變,而使其缺點影響層面愈來愈大,這些缺點主要集中在效能部份。因為HTTP主宰了Internet 的流量,因此,任何一點效能問題,都足以產生巨大的影響。

  在制定、設定HTTP時,可能也沒料想到今天應用的榮景。以今日瀏覽器所瀏覽的網頁來說,其中伴隨著的各種檔案不僅數量多,而且檔案長度也大,和十幾年前的情況相比又大有所不同了。

  HTTP既有版本的問題

   綜觀這十幾年來的應用,HTTP被觀察出那些傳輸效率上的缺點呢?首先,要先指出來,傳輸效率的不彰不見得單靠頻寬的擴增就能夠解決。的確,今日的頻寬 和十幾年前也是大幅成長、無法相提并論,因此,網路的基礎設施足以支持大檔案的應用。但是,增加頻寬可以降低傳輸大檔案的時間,卻無法解決HTTP協定本 質上所造成的“延遲(latency)”。

  HTTP 底層的協定是TCP,因此,當HTTP的客戶端想要取得一個檔案資源時,就必須在一個TCP連線上發出請求。HTTP是一個基于“請求-回應”的協定,也是說,總是由客戶端發出請求,而伺服器端對應一個回應。

  在HTTP的伺服器端收到請求資訊后,會開始處理該請求,在完成請求的處理之后,開始回傳回應的內容。當HTTP伺服器端在處理請求時,整個TCP連線其實處于一個閑置的情況,此外,客戶端所能做的事也只有等待。

   而且,通常一個要能夠在瀏覽器中瀏覽完整的網頁內容,這中間涉及許多的檔案需要透過HTTP去取得,而單一個TCP連線只能同時間處理一個檔案,為此, 瀏覽器通常都會同時建立多個連線,以利更快的取得多個檔案的內容。否則,以HTTP的天性,必須逐一等待伺服器傳輸完前一個檔案后,才能夠再繼續取得下一 個檔案。

  面對傳輸效率不佳的狀況

  在最早的HTTP/1.0協定中,每次發出一個HTTP的請求都需要重新建立一個TCP連線,當該請求的回應內容傳輸完畢之后,該TCP連線即會被切斷,而這是一個非常沒有效率的事情,怎么說呢?

   第一個原因,是TCP在建立連線時,連線的兩方需要完成一個所謂3-Way Handshaking的動作,這會造成不小的延遲。對于一些每建立一個 TCP連線,就會持續使用很長一段時間的應用來說,這個初始建立連線的延遲一點也不重要。例如,透過telnet協定連往BBS站時,只會建立一個TCP 連線,卻可以使用很長一段時間,這段建立連線所造成的延遲,就不影響整個大局。

  但是,對基于“請求-回應”模式的HTTP來說,如果透過HTTP回傳的檔案不夠大時,例如一個只有幾十 KB的HTML檔案,它可能不需要太多時間就可以完成傳輸,那么花在建立TCP連線上的延遲,占整體的比例就會高出很多。

  在HTTP/1.0中更糟的是,一旦完成傳輸后,就會切斷TCP連線,之后倘若要請求另一個檔案,又必須重新建立一個全新的TCP連線,這使得每次都需要反覆不斷花費高昂的代價,在建立 TCP 連線之上,但每個TCP連線,卻又可能只傳輸少許的資料,就又被切斷了。

  為此,在HTTP/1.1中,增加了讓連線“保持存活(Keep Alive)”的標頭(header),讓客戶端及伺服器端可以協調重復運用同一個TCP連線,每當客戶端接收完來自伺服器端的回應內容后,可以繼續在同一 TCP 連線里發出下一個請求。

  但這樣的設計可以讓情況好轉,但并沒有辦法完全解決,因為這個“保持存活”的情況,若是客戶端在一段時間內,并沒有繼續在TCP連線中發出下一個請求,此TCP連線亦會被切斷。

   讓我們想想網頁瀏覽的行為模式,通常都是在載入完諸多檔案完畢后,使用者開始花時間瀏覽。在載入諸多檔案時,“保持存活”的特性,可以避免重新建立太多 TCP連線,但是當使用者在瀏覽網頁時,瀏覽器常不會再發送太多的請求至伺服器端,此時,先前已建立的TCP連線就會被切斷。等待使用者再連結到下一個網 頁時,瀏覽器仍然必須重新建立若干個全新的TCP連線。

  建立TCP連線的額外負擔當中,除了上述的3-Way Handshaking之外,還有一個部分,就是 TCP 的“緩起步( slow start)”特性。

   TCP本身是一個具有流量控制(flow control),以及擁塞控制(congestion control)能力的協定,因此,它會試著估算單 位時間內要傳輸多少資料量最有效率。當頻寬本身不足時,若是單位時間內試著傳輸太多的資料量至另一端,但卻無法即時傳輸完成,就會造成擁塞。另一方面,若 是頻寬充足,但卻傳輸的太少,又會造成效率不彰、無法善用頻寬的情況。

  因此,TCP的演算法會盡量優化此事,而緩起步正是其演算法中的一環。TCP會逐步視情況擴展單位時間內所傳輸的資料量,但在網路連線剛建立之際,它會試著從很小的傳輸量開始嘗試,這使得在連線剛建立的初期,無法善用實際上可能十分充足的頻寬。

  會產生很多短命的TCP連線

   就和 3-Way Handshaking 一樣,對于那種生命期很短的TCP連線來說,所造成的延遲影響比例就相對高出許多。但HTTP協定本身,就 傾向于制造出諸多生命期很短的TCP連線,因此,我們可以說,因為 HTTP 的天性,使得這些延遲產生出比較大的負面效應。

  此外,同 時間多個TCP連線并行傳輸的情況,也可能讓 TCP 演算法在做流量及擁塞控制時的估算失準,造成了無法在 TCP 之上進行高效傳輸的結果。而每個客 戶端都會同時和伺服器端建立多個 TCP 連線的行為,也使得伺服器必須配置更多的網路連線資源來處理,例如占用更多的sockets及作業系統中的資 源。而為了處理更多的連線請求,在多執行緒或程序的資源負擔,也變得更重。

  所以總的來看,同時間多連線及短生命期傾向的TCP連線,正 是HTTP在效率上打折扣的原因。而這樣的觀察,也正一步一步的導引著、觸發著 HTTP改版的契機,其中影響最深遠的,莫過于 Google 的 SPDY了。而有了SPDY協定,才催生了之后改版的HTTP/2。

  在這一回里,我們談了舊有HTTP的問題,而在下一回,我將介紹HTTP/2的內容,以及所做的改進,是如何的解決舊有HTTP的毛病。


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲国产日韩一级| 亚洲国产视频一区二区| 影音先锋久久| 国产自产2019最新不卡| 国产日韩av高清| 国产精品入口福利| 欧美少妇一区二区| 欧美日韩国产精品一区二区亚洲| 欧美福利一区二区| 免费人成网站在线观看欧美高清 | 欧美精品91| 欧美精品1区2区3区| 欧美巨乳波霸| 欧美日韩不卡视频| 欧美日韩人人澡狠狠躁视频| 欧美日韩在线观看视频| 欧美午夜久久久| 国产精品女人网站| 国产精品综合色区在线观看| 国产欧美日本| 国产一区二区三区在线观看视频| 国产日韩在线视频| 极品日韩久久| 亚洲精品久久在线| 亚洲一级特黄| 欧美亚洲免费在线| 亚洲国产福利在线| 99riav国产精品| 在线一区二区视频| 亚洲欧美春色| 久久精品亚洲精品| 免费日韩av| 欧美视频精品在线| 国产午夜精品麻豆| 在线观看亚洲精品视频| 日韩一级二级三级| 亚洲欧美中文字幕| 亚洲激情二区| 亚洲午夜免费福利视频| 欧美中在线观看| 免费一区二区三区| 欧美日韩亚洲国产一区| 国产日产高清欧美一区二区三区| 国产综合在线视频| 亚洲美女精品成人在线视频| 亚洲自拍偷拍福利| 亚洲国产精品久久精品怡红院 | 欧美国产一区二区三区激情无套| 欧美日韩精品欧美日韩精品一| 国产精品久久久久久久久借妻| 国产亚洲欧美另类一区二区三区| 亚洲激情亚洲| 午夜亚洲影视| 99国产精品| 欧美有码视频| 欧美承认网站| 国产精品视频男人的天堂| 精品动漫3d一区二区三区免费| avtt综合网| 亚洲高清网站| 亚洲欧美国内爽妇网| 蜜桃伊人久久| 国产精品视频免费观看www| 亚洲国产91| 亚洲欧美日韩国产| 夜夜嗨av一区二区三区| 久久久久久久久久久久久女国产乱| 欧美久久视频| 狠狠色狠狠色综合日日小说| 99精品福利视频| 久久精品一二三区| 午夜在线a亚洲v天堂网2018| 欧美国产乱视频| 国产视频不卡| 一区二区三区蜜桃网| 亚洲黄页一区| 欧美在线免费观看亚洲| 欧美日韩在线免费观看| 亚洲电影视频在线| 欧美在线一区二区| 午夜精品理论片| 欧美日韩免费视频| 亚洲国产美女久久久久| 欧美一区国产二区| 亚洲欧洲99久久| 欧美日本一区| 亚洲电影免费| 久久精品视频一| 性欧美超级视频| 欧美日韩蜜桃| 亚洲激情欧美| 亚洲国产欧美一区二区三区同亚洲 | 亚洲第一视频| 久久精品国产清自在天天线| 国产精品成人免费精品自在线观看| 亚洲国产精品热久久| 亚洲第一精品福利| 久久精品亚洲国产奇米99| 国产精品爽爽爽| 亚洲视频在线观看| 亚洲一区二区三区午夜| 欧美日韩免费一区二区三区| 91久久嫩草影院一区二区| 亚洲电影免费观看高清完整版在线观看| 性久久久久久| 国产伦精品一区二区三区免费| 亚洲午夜极品| 亚洲欧美日韩直播| 国产精品v欧美精品v日本精品动漫| 亚洲精品欧美激情| 亚洲欧洲日夜超级视频| 欧美 日韩 国产一区二区在线视频 | 久久久亚洲欧洲日产国码αv| 国产欧美精品xxxx另类| 亚洲一区欧美二区| 午夜精品久久久久久久久久久| 国产精品福利网站| 亚洲网站在线播放| 午夜精品三级视频福利| 国产嫩草影院久久久久| 性欧美办公室18xxxxhd| 久久se精品一区二区| 国产日韩精品一区二区三区在线 | 一区二区欧美日韩视频| 亚洲一区二区不卡免费| 国产精品成人一区二区三区夜夜夜 | 亚洲电影免费在线| 91久久嫩草影院一区二区| 久久久久看片| 激情久久五月| 亚洲精品欧美专区| 欧美日韩国内自拍| 亚洲天堂视频在线观看| 午夜精品久久99蜜桃的功能介绍| 国产精品揄拍500视频| 欧美在线影院| 欧美v亚洲v综合ⅴ国产v| 亚洲精品视频在线看| 亚洲无线一线二线三线区别av| 国产精品成人播放| 欧美一二三区精品| 麻豆精品精品国产自在97香蕉| 亚洲国产精品日韩| 亚洲网站视频福利| 国产热re99久久6国产精品| 久久精品夜色噜噜亚洲a∨| 欧美成人一区二区三区| 亚洲免费av电影| 性高湖久久久久久久久| 黑人一区二区| 99综合在线| 国产精品一区在线观看| 亚洲高清不卡av| 欧美美女操人视频| 亚洲一区二区三区精品视频| 久久久激情视频| 亚洲三级免费电影| 性高湖久久久久久久久| 在线成人av.com| 亚洲一区二区三区乱码aⅴ蜜桃女| 国产精品伊人日日| 亚洲六月丁香色婷婷综合久久| 欧美小视频在线| 久久av一区二区三区亚洲| 欧美精品v日韩精品v韩国精品v| 亚洲午夜精品网| 老司机精品导航| 一区二区三区日韩精品视频| 久久久久se| 亚洲美女福利视频网站| 久久久精品国产一区二区三区| 亚洲级视频在线观看免费1级| 欧美亚洲三区| 亚洲破处大片| 久久精品亚洲| 一区二区三区日韩欧美| 老司机免费视频一区二区| 一区二区三区回区在观看免费视频| 久久久777| 亚洲天堂av在线免费| 欧美电影美腿模特1979在线看| 中文亚洲免费| 欧美99久久| 欧美一区二区福利在线| 欧美日韩一区免费| 最新日韩精品| 国产日韩精品一区观看| 夜夜爽99久久国产综合精品女不卡 | 久久福利影视| 国产精品成人国产乱一区| 亚洲黄色毛片| 国产欧美精品| 亚洲一区二区三区四区五区黄| 亚洲大胆视频| 久久久99国产精品免费| 亚洲一区二区三区久久| 欧美精品一区二区三| 亚洲国产另类精品专区| 国产欧美va欧美va香蕉在| 在线亚洲观看|