精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

HTTP/3 來了 !未來可期

開發(fā) 前端
本文基于興趣部落接入 HTTP/3 的實踐,聊一聊 HTTP/3 的原理以及業(yè)務(wù)接入的方式。

2015 年 HTTP/2 標(biāo)準(zhǔn)發(fā)表后,大多數(shù)主流瀏覽器也于當(dāng)年年底支持該標(biāo)準(zhǔn)。此后,憑借著多路復(fù)用、頭部壓縮、服務(wù)器推送等優(yōu)勢,HTTP/2 得到了越來越多開發(fā)者的青睞,不知不覺的 HTTP 已經(jīng)發(fā)展到了第三代。本文基于興趣部落接入 HTTP/3 的實踐,聊一聊 HTTP/3 的原理以及業(yè)務(wù)接入的方式。

1. HTTP/3 原理

1.1 HTTP 歷史

在介紹 HTTP/3 之前,我們先簡單看下 HTTP 的歷史,了解下 HTTP/3 出現(xiàn)的背景。

隨著網(wǎng)絡(luò)技術(shù)的發(fā)展,1999 年設(shè)計的 HTTP/1.1 已經(jīng)不能滿足需求,所以 Google 在 2009 年設(shè)計了基于 TCP 的 SPDY,后來 SPDY 的開發(fā)組推動 SPDY 成為正式標(biāo)準(zhǔn),不過最終沒能通過。不過 SPDY 的開發(fā)組全程參與了 HTTP/2 的制定過程,參考了 SPDY 的很多設(shè)計,所以我們一般認(rèn)為 SPDY 就是 HTTP/2 的前身。無論 SPDY 還是 HTTP/2,都是基于 TCP 的,TCP 與 UDP 相比效率上存在天然的劣勢,所以 2013 年 Google 開發(fā)了基于 UDP 的名為 QUIC 的傳輸層協(xié)議,QUIC 全稱 Quick UDP Internet Connections,希望它能替代 TCP,使得網(wǎng)頁傳輸更加高效。后經(jīng)提議,互聯(lián)網(wǎng)工程任務(wù)組正式將基于 QUIC 協(xié)議的 HTTP (HTTP over QUIC)重命名為 HTTP/3。

1.2 QUIC 協(xié)議概覽

TCP 一直是傳輸層中舉足輕重的協(xié)議,而 UDP 則默默無聞,在面試中問到 TCP 和 UDP 的區(qū)別時,有關(guān) UDP 的回答常常寥寥幾語,長期以來 UDP 給人的印象就是一個很快但不可靠的傳輸層協(xié)議。但有時候從另一個角度看,缺點可能也是優(yōu)點。QUIC(Quick UDP Internet Connections,快速 UDP 網(wǎng)絡(luò)連接) 基于 UDP,正是看中了 UDP 的速度與效率。同時 QUIC 也整合了 TCP、TLS 和 HTTP/2 的優(yōu)點,并加以優(yōu)化。用一張圖可以清晰地表示他們之間的關(guān)系。

那 QUIC 和 HTTP/3 什么關(guān)系呢?QUIC 是用來替代 TCP、SSL/TLS 的傳輸層協(xié)議,在傳輸層之上還有應(yīng)用層,我們熟知的應(yīng)用層協(xié)議有 HTTP、FTP、IMAP 等,這些協(xié)議理論上都可以運行在 QUIC 之上,其中運行在 QUIC 之上的 HTTP 協(xié)議被稱為 HTTP/3,這就是”HTTP over QUIC 即 HTTP/3“的含義。

因此想要了解 HTTP/3,QUIC 是繞不過去的,下面主要通過幾個重要的特性讓大家對 QUIC 有更深的理解。

1.3 零 RTT 建立連接

用一張圖可以形象地看出 HTTP/2 和 HTTP/3 建立連接的差別。

HTTP/2 的連接需要 3 RTT,如果考慮會話復(fù)用,即把第一次握手算出來的對稱密鑰緩存起來,那么也需要 2 RTT,更進(jìn)一步的,如果 TLS 升級到 1.3,那么 HTTP/2 連接需要 2 RTT,考慮會話復(fù)用則需要 1 RTT。有人會說 HTTP/2 不一定需要 HTTPS,握手過程還可以簡化。這沒毛病,HTTP/2 的標(biāo)準(zhǔn)的確不需要基于 HTTPS,但實際上所有瀏覽器的實現(xiàn)都要求 HTTP/2 必須基于 HTTPS,所以 HTTP/2 的加密連接必不可少。而 HTTP/3 首次連接只需要 1 RTT,后面的連接更是只需 0 RTT,意味著客戶端發(fā)給服務(wù)端的第一個包就帶有請求數(shù)據(jù),這一點 HTTP/2 難以望其項背。那這背后是什么原理呢?我們具體看下 QUIC 的連接過程。

Step1:首次連接時,客戶端發(fā)送 Inchoate Client Hello 給服務(wù)端,用于請求連接;

Step2:服務(wù)端生成 g、p、a,根據(jù) g、p 和 a 算出 A,然后將 g、p、A 放到 Server Config 中再發(fā)送 Rejection 消息給客戶端;

Step3:客戶端接收到 g、p、A 后,自己再生成 b,根據(jù) g、p、b 算出 B,根據(jù) A、p、b 算出初始密鑰 K。B 和 K 算好后,客戶端會用 K 加密 HTTP 數(shù)據(jù),連同 B 一起發(fā)送給服務(wù)端;

Step4:服務(wù)端接收到 B 后,根據(jù) a、p、B 生成與客戶端同樣的密鑰,再用這密鑰解密收到的 HTTP 數(shù)據(jù)。為了進(jìn)一步的安全(前向安全性),服務(wù)端會更新自己的隨機數(shù) a 和公鑰,再生成新的密鑰 S,然后把公鑰通過 Server Hello 發(fā)送給客戶端。連同 Server Hello 消息,還有 HTTP 返回數(shù)據(jù);

Step5:客戶端收到 Server Hello 后,生成與服務(wù)端一致的新密鑰 S,后面的傳輸都使用 S 加密。

這樣,QUIC 從請求連接到正式接發(fā) HTTP 數(shù)據(jù)一共花了 1 RTT,這 1 個 RTT 主要是為了獲取 Server Config,后面的連接如果客戶端緩存了 Server Config,那么就可以直接發(fā)送 HTTP 數(shù)據(jù),實現(xiàn) 0 RTT 建立連接。

這里使用的是 DH 密鑰交換算法,DH 算法的核心就是服務(wù)端生成 a、g、p 3 個隨機數(shù),a 自己持有,g 和 p 要傳輸給客戶端,而客戶端會生成 b 這 1 個隨機數(shù),通過 DH 算法客戶端和服務(wù)端可以算出同樣的密鑰。在這過程中 a 和 b 并不參與網(wǎng)絡(luò)傳輸,安全性大大提高。因為 p 和 g 是大數(shù),所以即使在網(wǎng)絡(luò)中傳輸?shù)?p、g、A、B 都被劫持,那么靠現(xiàn)在的計算機算力也沒法破解密鑰。

1.4 連接遷移

TCP 連接基于四元組(源 IP、源端口、目的 IP、目的端口),切換網(wǎng)絡(luò)時至少會有一個因素發(fā)生變化,導(dǎo)致連接發(fā)生變化。當(dāng)連接發(fā)生變化時,如果還使用原來的 TCP 連接,則會導(dǎo)致連接失敗,就得等原來的連接超時后重新建立連接,所以我們有時候發(fā)現(xiàn)切換到一個新網(wǎng)絡(luò)時,即使新網(wǎng)絡(luò)狀況良好,但內(nèi)容還是需要加載很久。如果實現(xiàn)得好,當(dāng)檢測到網(wǎng)絡(luò)變化時立刻建立新的 TCP 連接,即使這樣,建立新的連接還是需要幾百毫秒的時間。

QUIC 的連接不受四元組的影響,當(dāng)這四個元素發(fā)生變化時,原連接依然維持。那這是怎么做到的呢?道理很簡單,QUIC 連接不以四元組作為標(biāo)識,而是使用一個 64 位的隨機數(shù),這個隨機數(shù)被稱為 Connection ID,即使 IP 或者端口發(fā)生變化,只要 Connection ID 沒有變化,那么連接依然可以維持。

1.5 隊頭阻塞/多路復(fù)用

HTTP/1.1 和 HTTP/2 都存在隊頭阻塞問題(Head of line blocking),那什么是隊頭阻塞呢?

TCP 是個面向連接的協(xié)議,即發(fā)送請求后需要收到 ACK 消息,以確認(rèn)對方已接收到數(shù)據(jù)。如果每次請求都要在收到上次請求的 ACK 消息后再請求,那么效率無疑很低。后來 HTTP/1.1 提出了 Pipelining 技術(shù),允許一個 TCP 連接同時發(fā)送多個請求,這樣就大大提升了傳輸效率。

在這個背景下,下面就來談 HTTP/1.1 的隊頭阻塞。下圖中,一個 TCP 連接同時傳輸 10 個請求,其中第 1、2、3 個請求已被客戶端接收,但第 4 個請求丟失,那么后面第 5 - 10 個請求都被阻塞,需要等第 4 個請求處理完畢才能被處理,這樣就浪費了帶寬資源。

因此,HTTP 一般又允許每個主機建立 6 個 TCP 連接,這樣可以更加充分地利用帶寬資源,但每個連接中隊頭阻塞的問題還是存在。

HTTP/2 的多路復(fù)用解決了上述的隊頭阻塞問題。不像 HTTP/1.1 中只有上一個請求的所有數(shù)據(jù)包被傳輸完畢下一個請求的數(shù)據(jù)包才可以被傳輸,HTTP/2 中每個請求都被拆分成多個 Frame 通過一條 TCP 連接同時被傳輸,這樣即使一個請求被阻塞,也不會影響其他的請求。如下圖所示,不同顏色代表不同的請求,相同顏色的色塊代表請求被切分的 Frame。

事情還沒完,HTTP/2 雖然可以解決“請求”這個粒度的阻塞,但 HTTP/2 的基礎(chǔ) TCP 協(xié)議本身卻也存在著隊頭阻塞的問題。HTTP/2 的每個請求都會被拆分成多個 Frame,不同請求的 Frame 組合成 Stream,Stream 是 TCP 上的邏輯傳輸單元,這樣 HTTP/2 就達(dá)到了一條連接同時發(fā)送多條請求的目標(biāo),這就是多路復(fù)用的原理。我們看一個例子,在一條 TCP 連接上同時發(fā)送 4 個 Stream,其中 Stream1 已正確送達(dá),Stream2 中的第 3 個 Frame 丟失,TCP 處理數(shù)據(jù)時有嚴(yán)格的前后順序,先發(fā)送的 Frame 要先被處理,這樣就會要求發(fā)送方重新發(fā)送第 3 個 Frame,Stream3 和 Stream4 雖然已到達(dá)但卻不能被處理,那么這時整條連接都被阻塞。

不僅如此,由于 HTTP/2 必須使用 HTTPS,而 HTTPS 使用的 TLS 協(xié)議也存在隊頭阻塞問題。TLS 基于 Record 組織數(shù)據(jù),將一堆數(shù)據(jù)放在一起(即一個 Record)加密,加密完后又拆分成多個 TCP 包傳輸。一般每個 Record 16K,包含 12 個 TCP 包,這樣如果 12 個 TCP 包中有任何一個包丟失,那么整個 Record 都無法解密。

隊頭阻塞會導(dǎo)致 HTTP/2 在更容易丟包的弱網(wǎng)絡(luò)環(huán)境下比 HTTP/1.1 更慢!

那 QUIC 是如何解決隊頭阻塞問題的呢?主要有兩點。

  •  QUIC 的傳輸單元是 Packet,加密單元也是 Packet,整個加密、傳輸、解密都基于 Packet,這樣就能避免 TLS 的隊頭阻塞問題;
  •  QUIC 基于 UDP,UDP 的數(shù)據(jù)包在接收端沒有處理順序,即使中間丟失一個包,也不會阻塞整條連接,其他的資源會被正常處理。

1.6 擁塞控制

擁塞控制的目的是避免過多的數(shù)據(jù)一下子涌入網(wǎng)絡(luò),導(dǎo)致網(wǎng)絡(luò)超出最大負(fù)荷。QUIC 的擁塞控制與 TCP 類似,并在此基礎(chǔ)上做了改進(jìn)。所以我們先簡單介紹下 TCP 的擁塞控制。

TCP 擁塞控制由 4 個核心算法組成:慢啟動、擁塞避免、快速重傳和快速恢復(fù),理解了這 4 個算法,對 TCP 的擁塞控制也就有了大概了解。

  •  慢啟動:發(fā)送方向接收方發(fā)送 1 個單位的數(shù)據(jù),收到對方確認(rèn)后會發(fā)送 2 個單位的數(shù)據(jù),然后依次是 4 個、8 個……呈指數(shù)級增長,這個過程就是在不斷試探網(wǎng)絡(luò)的擁塞程度,超出閾值則會導(dǎo)致網(wǎng)絡(luò)擁塞;
  •  擁塞避免:指數(shù)增長不可能是無限的,到達(dá)某個限制(慢啟動閾值)之后,指數(shù)增長變?yōu)榫€性增長;
  •  快速重傳:發(fā)送方每一次發(fā)送時都會設(shè)置一個超時計時器,超時后即認(rèn)為丟失,需要重發(fā);
  •  快速恢復(fù):在上面快速重傳的基礎(chǔ)上,發(fā)送方重新發(fā)送數(shù)據(jù)時,也會啟動一個超時定時器,如果收到確認(rèn)消息則進(jìn)入擁塞避免階段,如果仍然超時,則回到慢啟動階段。

QUIC 重新實現(xiàn)了 TCP 協(xié)議的 Cubic 算法進(jìn)行擁塞控制,并在此基礎(chǔ)上做了不少改進(jìn)。下面介紹一些 QUIC 改進(jìn)的擁塞控制的特性。

1.6.1 熱插拔

TCP 中如果要修改擁塞控制策略,需要在系統(tǒng)層面進(jìn)行操作。QUIC 修改擁塞控制策略只需要在應(yīng)用層操作,并且 QUIC 會根據(jù)不同的網(wǎng)絡(luò)環(huán)境、用戶來動態(tài)選擇擁塞控制算法。

1.6.2 前向糾錯 FEC

QUIC 使用前向糾錯(FEC,F(xiàn)orward Error Correction)技術(shù)增加協(xié)議的容錯性。一段數(shù)據(jù)被切分為 10 個包后,依次對每個包進(jìn)行異或運算,運算結(jié)果會作為 FEC 包與數(shù)據(jù)包一起被傳輸,如果不幸在傳輸過程中有一個數(shù)據(jù)包丟失,那么就可以根據(jù)剩余 9 個包以及 FEC 包推算出丟失的那個包的數(shù)據(jù),這樣就大大增加了協(xié)議的容錯性。

這是符合現(xiàn)階段網(wǎng)絡(luò)技術(shù)的一種方案,現(xiàn)階段帶寬已經(jīng)不是網(wǎng)絡(luò)傳輸?shù)钠款i,往返時間才是,所以新的網(wǎng)絡(luò)傳輸協(xié)議可以適當(dāng)增加數(shù)據(jù)冗余,減少重傳操作。

1.6.3 單調(diào)遞增的 Packet Number

TCP 為了保證可靠性,使用 Sequence Number 和 ACK 來確認(rèn)消息是否有序到達(dá),但這樣的設(shè)計存在缺陷。

超時發(fā)生后客戶端發(fā)起重傳,后來接收到了 ACK 確認(rèn)消息,但因為原始請求和重傳請求接收到的 ACK 消息一樣,所以客戶端就郁悶了,不知道這個 ACK 對應(yīng)的是原始請求還是重傳請求。如果客戶端認(rèn)為是原始請求的 ACK,但實際上是左圖的情形,則計算的采樣 RTT 偏大;如果客戶端認(rèn)為是重傳請求的 ACK,但實際上是右圖的情形,又會導(dǎo)致采樣 RTT 偏小。圖中有幾個術(shù)語,RTO 是指超時重傳時間(Retransmission TimeOut),跟我們熟悉的 RTT(Round Trip Time,往返時間)很長得很像。采樣 RTT 會影響 RTO 計算,超時時間的準(zhǔn)確把握很重要,長了短了都不合適。

QUIC 解決了上面的歧義問題。與 Sequence Number 不同的是,Packet Number 嚴(yán)格單調(diào)遞增,如果 Packet N 丟失了,那么重傳時 Packet 的標(biāo)識不會是 N,而是比 N 大的數(shù)字,比如 N + M,這樣發(fā)送方接收到確認(rèn)消息時就能方便地知道 ACK 對應(yīng)的是原始請求還是重傳請求。

1.6.4 ACK Delay

TCP 計算 RTT 時沒有考慮接收方接收到數(shù)據(jù)到發(fā)送確認(rèn)消息之間的延遲,如下圖所示,這段延遲即 ACK Delay。QUIC 考慮了這段延遲,使得 RTT 的計算更加準(zhǔn)確。

1.6.5 更多的 ACK 塊

一般來說,接收方收到發(fā)送方的消息后都應(yīng)該發(fā)送一個 ACK 回復(fù),表示收到了數(shù)據(jù)。但每收到一個數(shù)據(jù)就返回一個 ACK 回復(fù)太麻煩,所以一般不會立即回復(fù),而是接收到多個數(shù)據(jù)后再回復(fù),TCP SACK 最多提供 3 個 ACK block。但有些場景下,比如下載,只需要服務(wù)器返回數(shù)據(jù)就好,但按照 TCP 的設(shè)計,每收到 3 個數(shù)據(jù)包就要“禮貌性”地返回一個 ACK。而 QUIC 最多可以捎帶 256 個 ACK block。在丟包率比較嚴(yán)重的網(wǎng)絡(luò)下,更多的 ACK block 可以減少重傳量,提升網(wǎng)絡(luò)效率。

1.7 流量控制

TCP 會對每個 TCP 連接進(jìn)行流量控制,流量控制的意思是讓發(fā)送方不要發(fā)送太快,要讓接收方來得及接收,不然會導(dǎo)致數(shù)據(jù)溢出而丟失,TCP 的流量控制主要通過滑動窗口來實現(xiàn)的。可以看出,擁塞控制主要是控制發(fā)送方的發(fā)送策略,但沒有考慮到接收方的接收能力,流量控制是對這部分能力的補齊。

QUIC 只需要建立一條連接,在這條連接上同時傳輸多條 Stream,好比有一條道路,兩頭分別有一個倉庫,道路中有很多車輛運送物資。QUIC 的流量控制有兩個級別:連接級別(Connection Level)和 Stream 級別(Stream Level),好比既要控制這條路的總流量,不要一下子很多車輛涌進(jìn)來,貨物來不及處理,也不能一個車輛一下子運送很多貨物,這樣貨物也來不及處理。

那 QUIC 是怎么實現(xiàn)流量控制的呢?我們先看單條 Stream 的流量控制。Stream 還沒傳輸數(shù)據(jù)時,接收窗口(flow control receive window)就是最大接收窗口(flow control receive window),隨著接收方接收到數(shù)據(jù)后,接收窗口不斷縮小。在接收到的數(shù)據(jù)中,有的數(shù)據(jù)已被處理,而有的數(shù)據(jù)還沒來得及被處理。如下圖所示,藍(lán)色塊表示已處理數(shù)據(jù),黃色塊表示未處理數(shù)據(jù),這部分?jǐn)?shù)據(jù)的到來,使得 Stream 的接收窗口縮小。

隨著數(shù)據(jù)不斷被處理,接收方就有能力處理更多數(shù)據(jù)。當(dāng)滿足 (flow control receive offset - consumed bytes) < (max receive window / 2) 時,接收方會發(fā)送 WINDOW_UPDATE frame 告訴發(fā)送方你可以再多發(fā)送些數(shù)據(jù)過來。這時 flow control receive offset 就會偏移,接收窗口增大,發(fā)送方可以發(fā)送更多數(shù)據(jù)到接收方。

Stream 級別對防止接收端接收過多數(shù)據(jù)作用有限,更需要借助 Connection 級別的流量控制。理解了 Stream 流量那么也很好理解 Connection 流控。Stream 中,接收窗口(flow control receive window) = 最大接收窗口(max receive window) - 已接收數(shù)據(jù)(highest received byte offset) ,而對 Connection 來說:接收窗口 = Stream1 接收窗口 + Stream2 接收窗口 + ... + StreamN 接收窗口 。

2. 總結(jié)

QUIC 丟掉了 TCP、TLS 的包袱,基于 UDP,并對 TCP、TLS、HTTP/2 的經(jīng)驗加以借鑒、改進(jìn),實現(xiàn)了一個安全高效可靠的 HTTP 通信協(xié)議。憑借著 0 RTT 建立連接、平滑的連接遷移、基本消除了隊頭阻塞、改進(jìn)的擁塞控制和流量控制等優(yōu)秀的特性,QUIC 在絕大多數(shù)場景下獲得了比 HTTP/2 更好的效果。

一周前,微軟宣布開源自己的內(nèi)部 QUIC 庫 -- MsQuic,將全面推薦 QUIC 協(xié)議替換 TCP/IP 協(xié)議。

HTTP/3 未來可期。 

 

責(zé)任編輯:龐桂玉 來源: 前端大全
相關(guān)推薦

2019-03-25 18:54:24

區(qū)塊鏈數(shù)字貨幣比特幣

2020-12-15 20:47:45

Check Point

2022-11-03 23:27:03

2020-12-28 15:08:38

數(shù)字化轉(zhuǎn)型技術(shù)

2022-07-19 08:04:04

HTTP應(yīng)用層協(xié)議

2020-07-17 10:22:16

人工智能技術(shù)疫情

2020-06-05 16:20:57

云計算

2019-06-14 14:30:33

HTTP3協(xié)議

2021-09-17 10:07:55

人工智能AI虹膜識別

2020-07-20 17:05:03

機器人工業(yè)機器人國產(chǎn)

2020-12-22 16:10:43

人工智能

2016-08-31 00:28:42

VR產(chǎn)業(yè)VR技術(shù)

2021-09-29 10:10:56

人工智能技術(shù)清華
點贊
收藏

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

亚洲免费伊人电影在线观看av| 亚洲三级电影全部在线观看高清| 国产91av在线| 六月婷婷七月丁香| 91福利精品在线观看| 日韩久久一区二区| 国产精品毛片一区视频| 亚洲一区欧美在线| 日韩欧美三级| 欧美精品一区二区三区蜜桃| caoporn超碰97| 日本电影一区二区在线观看| 裸体在线国模精品偷拍| 久久久亚洲成人| 国产视频不卡在线| 果冻天美麻豆一区二区国产| 欧美性生交片4| 久久精品无码中文字幕| www日韩tube| 成人白浆超碰人人人人| 国产剧情日韩欧美| 亚洲日本韩国在线| 欧美va天堂在线| 在线观看亚洲视频| 青青草视频网站| 精品视频在线一区| 欧美色成人综合| 欧美视频在线播放一区| 伊人精品影院| 中文字幕日本乱码精品影院| 欧美日韩另类丝袜其他| 午夜精品小视频| 精品影视av免费| 国产精品www| 成人免费看片98欧美| 午夜久久黄色| 久久久国产精品视频| 国产精品久久免费观看| 亚洲精品国产setv| 亚洲二区在线播放视频| 4438x全国最大成人| 亚州精品国产| 欧美精品九九99久久| 日韩在线xxx| 涩涩网在线视频| 性欧美疯狂xxxxbbbb| 小泽玛利亚av在线| 成人免费视屏| 亚洲男人的天堂一区二区| 在线丝袜欧美日韩制服| 男人的天堂在线视频免费观看 | 高h视频在线播放| 国产精品国产三级国产aⅴ中文| 青青草国产精品| 免费一级在线观看| 久久久欧美精品sm网站| 欧美在线视频二区| 国产污视频在线| 国产精品―色哟哟| 在线观看成人一级片| 大地资源网3页在线观看| 最新久久zyz资源站| 在线精品亚洲一区二区| 在线中文字幕电影| 亚洲图片欧美色图| 丰满的少妇愉情hd高清果冻传媒| 2021中文字幕在线| 福利一区福利二区微拍刺激| 亚洲人成无码www久久久| 粉嫩一区二区三区| 欧美日韩精品欧美日韩精品| 国产精品久久久久久久av福利| 国产午夜精品一区在线观看| 日韩美女视频在线| 丰满大乳奶做爰ⅹxx视频| 精品中文一区| www.亚洲一区| 国产一级二级三级| 国产欧美激情| 国产精品一区二区三区毛片淫片 | 亚洲成av人片在线观看香蕉| avtt香蕉久久| av资源久久| 日韩亚洲第一页| 精品99在线观看| 久久精品二区三区| 成人网欧美在线视频| 欧美一区二区三区成人片在线| 久久久久久久久99精品| 裸体大乳女做爰69| 欧美伦理91| 欧美精品黑人性xxxx| 亚洲精品国产成人av在线| 精品国产日韩欧美| 欧美黄色免费网站| 国产精品尤物视频| 成人免费观看视频| 亚洲欧洲一区二区福利| 白白色在线观看| 欧美日韩精品电影| 欲求不满的岳中文字幕| 香港欧美日韩三级黄色一级电影网站| 97久久伊人激情网| 国产原创中文av| 337p粉嫩大胆噜噜噜噜噜91av | 午夜伦理在线视频| 日本久久电影网| 久久人妻少妇嫩草av蜜桃| 精品久久不卡| 久久久免费精品视频| 亚洲天堂中文网| 91视视频在线直接观看在线看网页在线看| 亚洲精品国产精品久久 | 热久久这里只有精品| 精品国产伦一区二区三区| 国产午夜精品一区二区三区视频| 国产资源在线免费观看| 2019中文亚洲字幕| 亚洲色图50p| 日本一级淫片色费放| 精品亚洲国内自在自线福利| 欧美乱偷一区二区三区在线| 不卡一本毛片| 日韩女优制服丝袜电影| 任你操精品视频| 久久一区中文字幕| 国产精品一区二区不卡视频| 超碰在线观看免费版| 欧美综合一区二区| 国产高清自拍视频| 欧美视频久久| 亚洲精品女av网站| 午夜不卡视频| 欧美网站大全在线观看| 波多野结衣 在线| 亚洲欧洲综合| 国产精品日韩一区二区| 青草在线视频| 精品国免费一区二区三区| 无码 人妻 在线 视频| 国产亚洲综合精品| 国产女人水真多18毛片18精品 | 国产精品一区二区三区久久| 毛片网站在线| 91激情在线视频| 91中文字幕永久在线| 免费看黄裸体一级大秀欧美| 久久99精品久久久久久青青日本| h片在线观看视频免费| 精品国产一区二区三区四区四 | 久久只有这里有精品| 国产精品综合色区在线观看| 久久综合九色99| 欧美大片免费| 揄拍成人国产精品视频| 五月婷婷激情视频| 中文字幕精品一区二区精品绿巨人 | 头脑特工队2在线播放| 福利一区视频在线观看| 亚洲av无码一区二区三区人| 久久精品免费| 亚洲精品欧洲精品| 只有精品亚洲| 欧美激情久久久久久| 欧美一级性视频| 精品福利在线看| 法国伦理少妇愉情| 天堂在线亚洲视频| 一区二区三区四区五区视频| 91精品麻豆| 久久久久久伊人| 欧洲天堂在线观看| 欧美午夜寂寞影院| 18岁成人毛片| 99久久久久久99| av无码精品一区二区三区| 久久精品影视| 国产美女精品久久久| 成人黄色免费短视频| 中文亚洲视频在线| 亚洲av无码国产综合专区| 疯狂欧美牲乱大交777| 中国特黄一级片| 国产69精品久久久久777| 国产免费毛卡片| 97视频精品| 国产另类自拍| 国产91欧美| 韩国一区二区电影| 国产爆初菊在线观看免费视频网站 | 亚洲综合网狠久久| 8x拔播拔播x8国产精品| 日本在线看片免费人成视1000| 日韩欧美一区在线| 无码免费一区二区三区| 一级特黄大欧美久久久| 久久久无码人妻精品一区| 韩国v欧美v亚洲v日本v| 亚洲欧洲日产国码无码久久99| 欧美影院三区| 激情小说综合区| 欧美美女被草| 2019中文字幕在线免费观看| 里番在线观看网站| 亚洲精品有码在线| 国产高清视频免费| 在线一区二区视频| 欧美一区二区激情视频| 亚洲久草在线视频| 1024手机在线观看你懂的| 粉嫩aⅴ一区二区三区四区五区| av片中文字幕| 影音先锋一区| 无颜之月在线看| 成人同人动漫免费观看 | 天天av综合| 欧美一区二区三区四区在线观看地址| 88久久精品| 成人做爽爽免费视频| av激情成人网| 奇米影视亚洲狠狠色| 888av在线视频| 欧美乱大交xxxxx| 免费网站免费进入在线| 一夜七次郎国产精品亚洲| 天天躁日日躁狠狠躁喷水| 欧美一级理论性理论a| 91好色先生tv| 欧美午夜片在线观看| 黄瓜视频在线免费观看| 午夜激情一区二区三区| 精品无码m3u8在线观看| 中文字幕一区日韩精品欧美| 69xxx免费| 欧美经典一区二区三区| 欧美18—19性高清hd4k| 91蜜桃网址入口| av无码一区二区三区| 北条麻妃一区二区三区| aaaaa黄色片| 国产成人综合亚洲网站| 男插女视频网站| 国产精品影视网| 色诱av手机版| 成人在线一区二区三区| 国产麻豆剧传媒精品国产av| 成人中文字幕电影| 在线精品一区二区三区| 99久久久久久| 亚洲精品国产91| 国产欧美1区2区3区| 中国1级黄色片| 亚洲欧洲精品一区二区三区不卡| 91精品少妇一区二区三区蜜桃臀| 综合欧美亚洲日本| 一区二区三区四区五区| 一区二区三区在线观看国产| 国产在线观看99| 天天操天天综合网| 久久久黄色大片| 欧美少妇xxx| 91丨porny丨在线中文| 欧美一区二区三区系列电影| 精品国产免费无码久久久| 亚洲成人黄色网址| 青青草免费在线| 深夜精品寂寞黄网站在线观看| 日本在线免费播放| 欧美国产亚洲视频| 美女高潮视频在线看| 日韩av成人在线| 日韩av懂色| 国产精品免费看一区二区三区| 亚洲一区二区三区中文字幕在线观看 | 亚洲 高清 成人 动漫| 日韩精品成人一区二区三区| jizz18女人| 成人免费视频视频| 丰腴饱满的极品熟妇| 亚洲欧洲综合另类| 午夜影院在线看| 欧美三级韩国三级日本一级| 国产v片在线观看| 日韩经典一区二区三区| yiren22综合网成人| 欧美激情第三页| 先锋欧美三级| 99re在线观看| 国产欧美一区| 久久久久久久香蕉| 天堂久久久久va久久久久| 色婷婷激情视频| 91免费观看视频| 三级影片在线看| 色呦呦国产精品| 亚洲h视频在线观看| 国产亚洲欧美另类中文| 午夜伦理大片视频在线观看| 国产成人av在线| 91精品啪在线观看国产手机 | 少妇特黄一区二区三区| 17c精品麻豆一区二区免费| 激情五月色婷婷| 3atv一区二区三区| 黄色av网址在线免费观看| 久久99亚洲热视| 日韩高清在线| 精品国产乱码久久久久久88av| 久久久久久久久国产一区| 北条麻妃在线视频观看| 国产高清久久久| 欧美成人短视频| 亚洲777理论| 99久久精品无免国产免费| 亚洲欧美一区二区三区在线| 暖暖在线中文免费日本| 国产精品一二三在线| 卡通动漫国产精品| 国产1区2区3区中文字幕| 美腿丝袜亚洲色图| 蜜臀av一区二区三区有限公司| 亚洲一区二区在线观看视频| 国产精品伊人久久| 在线日韩av观看| 欧美电影免费看| 久久一区二区三区av| 亚洲毛片播放| 第一页在线视频| 一级日本不卡的影视| 国产精品-色哟哟| 中文字幕日韩欧美| 欧美va在线观看| 日韩欧美手机在线| 日韩精品国产精品| 人妻精品久久久久中文| 色狠狠桃花综合| 国产小视频福利在线| 欧美专区日韩视频| 欧美电影免费网站| 女人天堂av手机在线| 93久久精品日日躁夜夜躁欧美| 久久久久久久久久影院| 精品福利av导航| 1024在线看片你懂得| 韩国成人av| 国产精品综合色区在线观看| 真人bbbbbbbbb毛片| 精品福利一区二区| 奇米影视888狠狠狠777不卡| 国产99视频在线观看| 国产精品最新| 超碰av在线免费观看| 国产精品视频看| 一级α片免费看刺激高潮视频| www.午夜精品| 精品网站999| 欧美 日韩 亚洲 一区| 95精品视频在线| 午夜一区二区三区四区| 中文一区二区视频| 日韩中文一区二区| 成人在线免费观看视频网站| 国产·精品毛片| 影音先锋在线国产| 国产一区二区av| **日韩最新| 少妇高潮喷水在线观看| 久久午夜电影网| 欧美男人天堂网| 久久久国产精品一区| 露出调教综合另类| 可以免费在线看黄的网站| 亚洲四区在线观看| 人人妻人人澡人人爽久久av | 7m精品国产导航在线| 欧美变态另类刺激| 国产精品水嫩水嫩| 黄色av网站免费在线观看| 日本国产一区二区三区| 99国内精品久久久久久久| 成年女人免费视频| 色婷婷久久99综合精品jk白丝| 麻豆免费在线视频| 精品蜜桃一区二区三区| 青青草国产成人av片免费| 免费一级黄色大片| 亚洲亚裔videos黑人hd| 视频在线亚洲| 不卡av免费在线| 亚洲国产精品一区二区久久恐怖片| 你懂的视频在线| 96成人在线视频| 日本视频在线一区| 久一区二区三区| 色爱av美腿丝袜综合粉嫩av | 国产成人亚洲精品青草天美| 亚洲精品中文字幕乱码三区91| 久久精品国产91精品亚洲| 久久草在线视频| 日本中文字幕观看|