成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

QUIC通信協議簡介

網絡
本文主要對QUIC協議概念背景以及該協議的優缺點進行了簡要的概述,同時舉例了該協議的應用場景,方便大家對該協議有一個初步的了解。

Part 01

什么是QUIC 

QUIC(Quick UDP Internet Connection)是Google提出的一個基于UDP的傳輸協議,因其高效的傳輸效率和多路并發的能力,已經成為下一代互聯網協議HTTP/3的底層傳輸協議,2021年5月IETF公布RFC9000,QUIC規范推出了標準化版本。除了應用于Web領域,它的優勢同樣適用于一些通用的需要低延遲、高吞吐特性的傳輸場景。

從協議棧可以看出:QUIC = HTTP/2 + TLS + UDP

圖片

Part 02

為什么要有QUIC 

HTTP從最初的HTTP/0.9,經歷了HTTP/1.x,HTTP/2到最新的HTTP/3這幾個大的迭代。在HTTP/3版本之前,HTTP底層都是用TCP傳輸數據,而伴隨著移動互聯網的發展,網絡交互場景越來越豐富并要求及時性,傳統TCP固有的性能瓶頸越來越不能滿足需求,原因有以下幾點:

- 建立連接的握手延遲大

HTTPS包含兩個握手:1)TCP三次握手,1個RTT;2)TLS握手,2個RTT。完整握手總共需要3個RTT,對于直播等需要首幀秒開場景,握手延遲太大。

- 多路復用的隊首阻塞

以HTTP/2多路復用為例,多個數據請求作為不同的流,共用一條TCP連接發送,所有的流應用層都必須按序處理。若某個流的數據丟失,后面其他流的數據都會被阻塞,直到丟失的流數據重傳完成其他流才能被繼續傳輸。即使接收端已經收到之后流的數據包,HTTP協議也不會通知應用層去處理。

- TCP協議的更新滯后

TCP協議實現在操作系統內核內,但是用戶端的操作系統版本升級非常困難,很多老舊的系統還有大量用戶使用,因此TCP協議的一些更新很難被快速推廣。

正是考慮到以上的這些問題,QUIC在應用層之上基于UDP實現丟包恢復,擁塞控制,加解密,多路復用等功能,既能優化握手延遲,同時又完全解決內核協議更新滯后問題。

Part 03

QUIC建立連接的過程 

QUIC建立連接步驟比較簡單,流程如下:

圖片

1)客戶端發起Inchoate client hello;

2)服務器返回Rejection,包括密鑰交換算法的公鑰信息,算法信息,證書信息等被放到server config中傳給客戶端;

3)客戶端發起client hello,包括客戶端公鑰信息。

此時,雙方各自計算出了對稱密鑰。QUIC的1次RTT建連過程結束,平均只耗時100ms以內。后續發起連接的過程中,一旦客戶端緩存或持久化了server config,就可以復用并結合本地生成的私鑰進行加密數據傳輸,不需要再次握手,從而實現0次RTT建立連接。

Part 04

QUIC的優缺點 

4.1 QUIC的優勢體現在如下方面:

(1)可擴展性強。更改TCP并不容易,因為其中的中間件抗拒更新,而且TCP 40字節的可選位幾乎全部填滿。TCP沒有任何版本協商(version negotiation)擴展位,相比之下,QUIC有32位,所以它有很多空間部署新版本,廠商也可以利用這些空間定義自己的專屬版本。

(2)用戶空間實現容易。QUIC能夠在應用層實現,與在操作系統內核中實現的TCP相比,它可以更快地進行更新。這進一步提高了QUIC的可擴展性,使得服務可以非常快速地演進,從而新的特性每天都能得到部署。同時它還能在上下文切換時通過調用較少的開銷而實現更高的響應能力。

(3)建立連接更加快速。Web瀏覽特別需要快速建立連接,因為用戶通常會開啟多個、短暫的連接。當使用HTTPS時,TCP在建立連接前,需要“三次握手”以及后續的TLS協議設置。QUIC(基于UDP)不需要三次握手,加上它會在初次握手時交換安全密鑰,從而使它在建立加密連接時速度提升了一倍。

(4)丟包敏感度較低。使用TCP時,如果丟失一個數據包,接下來所有的數據包都會停止傳輸,直到丟失的那個數據包被發送,這種現象被稱為“隊頭阻塞”,它會導致延遲明顯增加。相比之下,QUIC使用的是類似HTTP/2的多路復用模式,可以同時支持多個數據流。如果一個數據流發送錯誤,導致丟包,那么其他數據流會繼續發送數據包,而不會阻塞傳輸。

(5)切換網絡時的性能提升較高。切換網絡時,QUIC可以實現平穩過渡。比如,當你使用家里的Wi-Fi觀看手機上的視頻,然后你走出家門,家里的Wi-Fi便切換到LTE;或者當你一直忙于觀看視頻,在不同的移動基站間移動時;在以上這些場景中,TCP將切斷連接,并通過新的網絡創建新的連接,進而影響到你的觀看體驗,而QUIC則能夠實現無縫連接。

(6)安全性和隱私保護較高。QUIC在傳輸層中內置了加密功能,從而驗證整個負載(包括header)。TCP在header中不包含加密,使它非常容易受到攻擊。QUIC默認支持安全的TLS,意味著端到端完全安全。

4.2 QUIC的劣勢體現在如下方面:

TCP發明時,網絡都是有線連接,而且相當可靠,QUIC對非可靠、無法預測的無線連接進行了改進,但并沒有改變互聯網傳輸的本質,它的局限性導致它只能改變某些特定使用場景。下面列舉了一些額外的QUIC局限性:

(1)遷移app面臨巨大挑戰。將app從HTTP/2遷移到HTTP/3(或者從TCP遷移到UDP)要費很大力氣。整個過程需要將應用層實現和傳輸層實現轉移到UDP,并在服務端和客戶端構建全新的解決方案。這對于流媒體領域中資源相對有限的小廠商而言無疑挑戰重重,同時也解釋了谷歌和微軟這樣的科技巨頭可以率先采用QUIC協議的原因。

(2)采用受限。QUIC的最大問題就是它的采用依然受限。幾乎每個瀏覽器都接受使用QUIC進行簡單的網頁瀏覽,但是除了chromium,沒有瀏覽器將它設置為默認選項。除此之外,在流媒體領域,除了谷歌和Facebook之外,少有公司使用QUIC。只有少數CDN提供商支持QUIC,而其中的一些也只是驗證了QUIC的實現,并沒有為大規模部署準備好。這就帶來了問題:如果你推出了使用multi-CDN并基于QUIC的新服務,那么將只有20%的訪問使用QUIC,因為你無法向用戶證明它對用戶體驗的顯著影響。

(3)QUIC包含TCP回退。QUIC之所以被構建在UDP之上,部分原因是極少有中間件和網絡設備攔截UDP。但確實存在被攔截的風險,所以基于QUIC的app必須設計成能夠回退到TCP,以防萬一。這意味著app(基于QUIC)的開發者要同時開發和維護兩個不同的版本(由于TCP回退和受到限制的采用率),導致他們的負擔很重。好消息是,隨著最新的DEVOPS結構與HTTP的Alt-Svc標簽的使用,支持兩種協議要比以前簡單得多。

(4)無法檢查數據包。網絡防火墻無法解密QUIC流量來檢查數據包,所以潛在的惡意流量非常有可能沒有被標準安全功能檢測出來而進入網絡。因此,思科和Palo Alto Networks等安全廠商通常會在端口80(Web服務器)和443(TSL)攔截QUIC數據包(認為它們包含惡意軟件),迫使客戶端回退使用HTTP/2和TCP協議。但上述操作并不會顯著影響內容用戶體驗,因為正確實現的流媒體服務會默認回退到TCP+TLS,但這種操作可能會阻止率先部署QUIC的想法。只有解決這一挑戰,QUIC才能被各大企業廣泛接受。

Part 05

QUIC在實際場景中的使用 

5.1 QUIC在MQTT通信場景中的應用前景

MQTT是基于TCP的物聯網通信協議,緊湊的報文結構能夠在嚴重受限的硬件設備和低帶寬、高延遲的網絡上實現穩定傳輸;心跳機制、遺囑消息、QoS質量等級等諸多特性能夠應對各種物聯網場景。盡管如此,由于底層TCP傳輸協議限制,某些復雜網絡環境下 MQTT 協議存在固有的弊端:

  • 網絡切換導致經常性連接中斷;
  • 斷網后重新建立連接困難:斷網后操作系統釋放資源較慢,且應用層無法及時感知斷開狀態,重連時Server/Client開銷較大;
  • 弱網環境下數據傳輸受限于擁塞、丟包偵測和重傳機制。

例如車聯網用戶通常會面對類似的問題:車輛可能會運行在山區、礦場、隧道等地方,當進入到信號死角或被動切換基站時會導致連接中斷,頻繁連接中斷與較慢的連接恢復速度會導致用戶體驗變差。在一些對數據傳輸實時性和穩定性要求較高的業務,如L4級別的無人駕駛中,客戶需要花費大量的成本來緩解這一問題。

在上述這類場景中,QUIC低連接開銷和多路徑支持的特性就顯示出了其優勢,基于QUIC 0 RTT/1 RTT重連/新建能力,能夠在弱網與不固定的網絡通路中有效提升用戶體驗。

5.2 QUIC協議在CDN加速方面的應用

傳統CDN會有多級結構,每一級結構會有不同熱度數據。在CDN節點之間有大量的通訊數據,這些數據進行分布式存儲時的路徑對最終CDN服務質量有著非常重要的影響。通常來說影響通訊質量的因素通常會受到緩存業務內容的性質、節點間的網絡連接和Client-server側的傳輸架構和機制的影響。這些層級間的數據拉取性能會直接影響到整體CDN的下發響應速度。通常可以通過TCP優化手段(數據連接池、TCP優化)、緩存數據分塊、高層級向低層次的數據推送、緩存數據預拉取、數據壓縮等手段實現超遠節點之間的進一步傳輸。

在這種情況下,QUIC的優勢就展現出來了。CDN QUIC服務針對業務場景進行了全面優化,包括4個方面:

  • 連接優化0-RTT連接復用率,降低連接的延遲。
  • 加解密優化明文傳輸,可以減少加解密造成的一些影響。
  • 傳輸優化亂序報文緩存,針對特殊數據優先級需求進行調整。
  • 針對線上的不同業務場景調整參數,利用擁塞算法,提升在不同業務場景下的效果。

Part 06

總結 

本文主要對QUIC協議概念背景以及該協議的優缺點進行了簡要的概述,同時舉例了該協議的應用場景,方便大家對該協議有一個初步的了解。目前該協議大型互聯網公司都有在不同的業務場景中使用,得到了不錯的性能提升。中國移動也在積極探索新技術,用技術改變生活。

責任編輯:龐桂玉 來源: 移動Labs
相關推薦

2023-10-12 19:37:50

通信協議HTTP

2010-06-11 14:31:08

通信協議

2019-05-27 06:05:20

物聯網協議物聯網IOT

2010-07-06 17:14:03

網關通信協議

2010-06-11 14:25:08

通信協議

2010-06-25 14:43:46

通信協議

2010-06-09 10:43:54

廣義網協議

2019-08-23 12:49:18

USB通信協議

2009-12-22 09:37:47

網關設置通信協議

2019-04-29 10:26:49

TCP網絡協議網絡通信

2023-10-28 16:14:38

RS485通信協議

2024-02-20 19:53:57

網絡通信協議

2023-04-27 17:49:38

物聯網通信協議

2010-06-09 11:31:55

網絡通信協議

2024-01-23 12:47:27

2021-12-16 10:49:32

物聯網通信協議網絡

2020-06-01 14:15:57

物聯網通信協議無線通訊

2019-07-30 15:50:00

2010-07-01 15:45:22

網絡通信協議

2021-05-29 16:12:00

通信協議設備
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 性福视频在线观看 | 日韩中文字幕免费 | 9久久精品 | 国产99小视频 | 九九热最新视频 | 久久久www成人免费精品张筱雨 | 91精品国产乱码久久久 | 亚洲第一在线 | 国产一区免费视频 | 久久久久国产一级毛片高清网站 | 97精品久久 | 国产精品亚洲片在线播放 | 亚洲精品免费看 | 日本小电影在线 | 亚洲精品久久久久久国产精华液 | 欧美专区在线观看 | 亚洲精品免费看 | 亚洲在线免费 | 欧美一区二区三区视频在线播放 | 一区二区三区视频在线观看 | 精品一区免费 | 午夜小视频在线播放 | 男人天堂色 | 91久久精品一区二区二区 | 国产乱码精品一区二区三区中文 | 一级在线毛片 | 欧美成人免费在线视频 | 精品动漫一区 | 日本精品一区二区三区视频 | 久国产视频 | 午夜精品一区二区三区在线观看 | 亚洲天堂中文字幕 | 免费观看的黄色网址 | 国产精品美女久久久久久久久久久 | 羞羞视频在线观看 | 美女视频网站久久 | 在线看一区二区 | 亚洲免费人成在线视频观看 | 韩国av电影网 | 欧美一级三级在线观看 | 亚洲国产一区在线 |