聶永的博客

          記錄工作/學(xué)習(xí)的點(diǎn)點(diǎn)滴滴。

          HTTP/2筆記之開篇

          前言

          本系列基于HTTP/2第17個(gè)草案文檔,地址就是:https://tools.ietf.org/html/draft-ietf-httpbis-http2-17。

          HTTP/2規(guī)范已經(jīng)通過發(fā)布批準(zhǔn),下面等待分配具體的RFC號(hào)碼,不會(huì)有所較大的變動(dòng)了。

          本筆記不是直接翻譯,記錄成筆記方便以后學(xué)習(xí)。

          HTTP/1.1的問題

          一張圖可以很較為全面的概括了HTTP/1.*存在缺陷:

          前端一般采用: - CSS Spriting,小圖合并成大圖,CSS進(jìn)行分割成小圖顯示 - Inlining,使用DataURL方式內(nèi)嵌Base64編碼格式圖片 - JS Concatenation,多個(gè)JS文件合并成一個(gè),缺陷是一旦有文件修改,需要重新合并 - Sharding,將資源/服務(wù)部署到多個(gè)機(jī)器上,均攤/分享請(qǐng)求壓力

          HTTP/1.*沒有充分利用TCP特性,再加上同一個(gè)站點(diǎn)打開多個(gè)連接等,導(dǎo)致網(wǎng)絡(luò)資源利用率不高。

          HTTP/2改進(jìn)點(diǎn)

          與HTTP/1相比,主要區(qū)別包括:

          1. HTTP/2采用二進(jìn)制格式而非文本格式
            • 高效緊湊傳輸解析
            • 更少錯(cuò)誤傾向,沒有了所謂的空白行、大寫、換行符、空連接等
          2. HTTP/2是完全多路復(fù)用的,而非有序并阻塞的
            • HTTP/1.1默認(rèn)情況下單個(gè)請(qǐng)求單個(gè)連接
            • HTTP/1.1流水線化pipelining方式導(dǎo)致較大/較慢的響應(yīng)阻塞后續(xù)任務(wù)
            • HTTP/1.1無法解決線頭阻塞的問題
            • 多路復(fù)用可以有效避免線頭阻塞,多個(gè)請(qǐng)求-響應(yīng)同一個(gè)連接內(nèi)并行處理
          3. 只需一個(gè)連接即可實(shí)現(xiàn)并行
            • HTTP/1.*請(qǐng)求處理模型導(dǎo)致同一個(gè)站點(diǎn)資源客戶端需要打開若4-8個(gè)連接請(qǐng)求
            • HTTP/1.*多個(gè)連接會(huì)占用過多網(wǎng)路資源,導(dǎo)致TCP堵塞和數(shù)據(jù)重傳
            • HTTP/2單個(gè)連接內(nèi)多個(gè)流(請(qǐng)求-響應(yīng))之間并行處理,減少網(wǎng)路資源占用,可避免了TCP頻繁的打開、關(guān)閉
          4. 使用報(bào)頭壓縮,HTTP/2降低了開銷
            • 傳統(tǒng)瀏覽器網(wǎng)路報(bào)頭一般在80-1400字節(jié)大小
            • 壓縮頭部可讓報(bào)頭更緊湊,更快速傳輸,有利于移動(dòng)網(wǎng)絡(luò)環(huán)境等
            • 壓縮算法使用HPACK,更為高效、安全
          5. HTTP/2讓服務(wù)器可以將響應(yīng)主動(dòng)“推送”到客戶端
            • 傳統(tǒng)方式:客戶端請(qǐng)求,服務(wù)器響應(yīng),客戶端逐一解析需要后續(xù)請(qǐng)求的圖片、樣式等資源,再次一一發(fā)送資源請(qǐng)求
            • HTTP/2服務(wù)器根據(jù)客戶端請(qǐng)求,計(jì)算出響應(yīng)內(nèi)容所包含的資源,在客戶端發(fā)起請(qǐng)求之前提前發(fā)送給客戶端
            • 節(jié)省客戶端主動(dòng)發(fā)起請(qǐng)求的時(shí)間的往返時(shí)間

          這里有一張圖,可以總體上了解HTTP/2:

          HTTP/2的解讀

          保留/兼容HTTP/1.1的所有語義,但傳輸語法(或者說傳輸方式)改變,目的在于更充分利用TCP更高效傳輸,多路復(fù)用是實(shí)現(xiàn)途徑,低延遲是改進(jìn)方向。

          筆記提綱

          以上為簡單總體介紹了HTTP/2協(xié)議,要想深入其特性,需要閱讀器規(guī)范。下面為圍繞HTTP/2規(guī)范的各個(gè)方面,列出提綱,便于后面一一填充。

          1. HTTP/2的連接建立
          2. HTTP/2的多路復(fù)用和流的屬性
          3. HTTP/2的幀定義
          4. HTTP/2的消息交換
          5. HTTP/2的錯(cuò)誤處理和安全事項(xiàng)

          名詞解釋

          以下名詞會(huì)在當(dāng)前或以后筆記中出現(xiàn),貼出來方便理解。

          1. 中介(intermediation),指代包含代理、企業(yè)防火墻、反向代理和CDN等互聯(lián)網(wǎng)設(shè)備
          2. ALPN,Application Layer Protocol Negotiation
          3. 報(bào)頭,報(bào)文頭部,請(qǐng)求報(bào)文頭部,或響應(yīng)報(bào)文頭部

          小結(jié)

          HTTP/2相比HTTP/1.1,可以做到更有效的充分利用TCP連接,避免了TCP連接的重復(fù)的創(chuàng)建(三次握手)、銷毀(四次揮手)的過程。

          引用

          1. 《HTTP/2 WebRTC all the things !》
          2. 《Implementing HTTP/2 client in 60 minutes》

          posted on 2015-03-17 14:50 nieyong 閱讀(6782) 評(píng)論(3)  編輯  收藏 所屬分類: HTTP

          評(píng)論

          # re: HTTP/2筆記之開篇[未登錄] 2015-03-17 19:35 simon

          “線頭”是指?  回復(fù)  更多評(píng)論   

          # re: HTTP/2筆記之開篇[未登錄] 2015-03-17 19:38 simon

          翻譯的不好。  回復(fù)  更多評(píng)論   

          # re: HTTP/2筆記之開篇 2015-03-18 14:02 nieyong

          @simon
          線頭阻塞,這里指的是多個(gè)請(qǐng)求排隊(duì)等待前面請(qǐng)求完成,后續(xù)的請(qǐng)求只有前面的請(qǐng)求完成了,才有機(jī)會(huì)得到處理。串行化方式,一個(gè)一個(gè)處理,一旦有阻塞,后續(xù)的任務(wù)只能被動(dòng)等待。
          HTTP/1.1 pipelining會(huì)導(dǎo)致線頭阻塞的問題。  回復(fù)  更多評(píng)論   

          公告

          所有文章皆為原創(chuàng),若轉(zhuǎn)載請(qǐng)標(biāo)明出處,謝謝~

          新浪微博,歡迎關(guān)注:

          導(dǎo)航

          <2015年3月>
          22232425262728
          1234567
          891011121314
          15161718192021
          22232425262728
          2930311234

          統(tǒng)計(jì)

          常用鏈接

          留言簿(58)

          隨筆分類(130)

          隨筆檔案(151)

          個(gè)人收藏

          最新隨筆

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 治多县| 珠海市| 山阳县| 西和县| 友谊县| 渝北区| 措勤县| 张掖市| 永嘉县| 五莲县| 麻栗坡县| 开鲁县| 乌拉特中旗| 闵行区| 永安市| 乌审旗| 广灵县| 嘉黎县| 苍山县| 陵川县| 木里| 富民县| 吉安县| 华阴市| 肇源县| 丹寨县| 元氏县| 璧山县| 特克斯县| 汉寿县| 共和县| 永康市| 阳春市| 志丹县| 桃园市| 博客| 子长县| 弥渡县| 东乡族自治县| 龙州县| 慈利县|