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

RPC 的概念模型與實現解析

開發 開發工具
一個RPC實現的概念框架,并詳細分析了需要考慮的一些實現細節。無論 RPC 的概念是如何優雅,但是“草叢中依然有幾條蛇隱藏著”,只有深刻理解了 RPC 的本質,才能更好地應用。

[[181522]]

今天分布式應用、云計算、微服務大行其道,作為其技術基石之一的 RPC 你了解多少?一篇 RPC 的技術總結文章,數了下 5k+ 字,略長,可能也不適合休閑的碎片化時間閱讀,可以先收藏抽空再細讀 :)

全文目錄如下:

  • 定義
  • 起源
  • 目標
  • 分類
  • 結構
  • 模型
  • 拆解
  • 組件
  • 實現
  • 導出
  • 導入
  • 協議
  • 編解碼
  • 消息頭
  • 消息體
  • 傳輸
  • 執行
  • 異常
  • 總結
  • 參考

兩年前寫過兩篇關于 RPC 的文章,如今回顧發現結構和邏輯略顯凌亂,特作整理重新整合成一篇,想了解 RPC 原理的同學可以看看。

近幾年的項目中,服務化和微服務化漸漸成為中大型分布式系統架構的主流方式,而 RPC 在其中扮演著關鍵的作用。 在平時的日常開發中我們都在隱式或顯式的使用 RPC,一些剛入行的程序員會感覺 RPC 比較神秘,而一些有多年使用 RPC 經驗的程序員雖然使用經驗豐富,但有些對其原理也不甚了了。 缺乏對原理層面的理解,往往也會造成開發中的一些誤用。

定義

RPC 的全稱是 Remote Procedure Call 是一種進程間通信方式。 它允許程序調用另一個地址空間(通常是共享網絡的另一臺機器上)的過程或函數,而不用程序員顯式編碼這個遠程調用的細節。即程序員無論是調用本地的還是遠程的函數,本質上編寫的調用代碼基本相同。

起源

RPC 這個概念術語在上世紀 80 年代由 Bruce Jay Nelson(參考[1])提出。 這里我們追溯下當初開發 RPC 的原動機是什么?在 Nelson 的論文 Implementing Remote Procedure Calls(參考[2]) 中他提到了幾點:

簡單:RPC 概念的語義十分清晰和簡單,這樣建立分布式計算就更容易。

高效:過程調用看起來十分簡單而且高效。

通用:在單機計算中「過程」往往是不同算法部分間最重要的通信機制。

通俗一點說,就是一般程序員對于本地的過程調用很熟悉,那么我們把 RPC 做成和本地調用完全類似,那么就更容易被接受,使用起來毫無障礙。 Nelson 的論文發表于 30 年前,其觀點今天看來確實高瞻遠矚,今天我們使用的 RPC 框架基本就是按這個目標來實現的。

目標

RPC 的主要目標是讓構建分布式計算(應用)更容易,在提供強大的遠程調用能力時不損失本地調用的語義簡潔性。 為實現該目標,RPC 框架需提供一種透明調用機制讓使用者不必顯式的區分本地調用和遠程調用。

分類

RPC 調用分以下兩種:

  • 同步調用:客戶端等待調用執行完成并獲取到執行結果。
  • 異步調用:客戶端調用后不用等待執行結果返回,但依然可以通過回調通知等方式獲取返回結果。若客戶端不關心調用返回結果,則變成單向異步調用,單向調用不用返回結果。

異步和同步的區分在于是否等待服務端執行完成并返回結果。

結構

下面我們對 RPC 的結構從理論模型到真實組件一步步抽絲剝繭。

模型

最早在 Nelson 的論文中指出實現 RPC 的程序包括 5 個理論模型部分:

  • User
  • User-stub
  • RPCRuntime
  • Server-stub
  • Server

這 5 個部分的關系如下圖所示:

這里 User 就是 Client 端。當 User 想發起一個遠程調用時,它實際是通過本地調用 User-stub。 User-stub 負責將調用的接口、方法和參數通過約定的協議規范進行編碼并通過本地的 RPCRuntime 實例傳輸到遠端的實例。 遠端 RPCRuntime 實例收到請求后交給 Server-stub 進行解碼后發起向本地端 Server 的調用,調用結果再返回給 User 端。

拆解

上面給出了一個比較粗粒度的 RPC 實現理論模型概念結構,這里我們進一步細化它應該由哪些組件構成,如下圖所示。

RPC 服務端通過 RpcServer 去導出(export)遠程接口方法,而客戶端通過 RpcClient 去導入(import)遠程接口方法。客戶端像調用本地方法一樣去調用遠程接口方法,RPC 框架提供接口的代理實現,實際的調用將委托給代理 RpcProxy。代理封裝調用信息并將調用轉交給 RpcInvoker 去實際執行。在客戶端的 RpcInvoker 通過連接器 RpcConnector 去維持與服務端的通道 RpcChannel,并使用 RpcProtocol 執行協議編碼(encode)并將編碼后的請求消息通過通道發送給服務端。

RPC 服務端接收器 RpcAcceptor 接收客戶端的調用請求,同樣使用 RpcProtocol執行協議解碼(decode)。

解碼后的調用信息傳遞給 RpcProcessor 去控制處理調用過程,***再委托調用給 RpcInvoker 去實際執行并返回調用結果。

組件

上面我們進一步拆解了 RPC 實現結構的各個組件組成部分,下面我們詳細說明下每個組件的職責劃分。

1.RpcServer

負責導出(export)遠程接口

2.RpcClient

負責導入(import)遠程接口的代理實現

3.RpcProxy

遠程接口的代理實現

4.RpcInvoker

客戶端:負責編碼調用信息和發送調用請求到服務端并等待調用結果返回

服務端:負責調用服務端接口的具體實現并返回調用結果

5.RpcProtocol

負責協議編/解碼

6.RpcConnector

負責維持客戶端和服務端的連接通道和發送數據到服務端

7.RpcAcceptor

負責接收客戶端請求并返回請求結果

8.RpcProcessor`

負責在服務端控制調用過程,包括管理調用線程池、超時時間等

9.RpcChannel

數據傳輸通道

實現

Nelson 論文中給出的這個概念模型也成為后來大家參考的標準范本。十多年前,我最早接觸分布式計算時使用的 CORBAR(參考[3])實現結構基本與此基本類似。CORBAR 為了解決異構平臺的 RPC,使用了 IDL(Interface Definition Language)來定義遠程接口,并將其映射到特定的平臺語言中。

后來大部分的跨語言平臺 RPC 基本都采用了此類方式,比如我們熟悉的 Web Service(SOAP),近年開源的 Thrift 等。 他們大部分都通過 IDL 定義,并提供工具來映射生成不同語言平臺的 User-stub 和 Server-stub,并通過框架庫來提供 RPCRuntime 的支持。 不過貌似每個不同的 RPC 框架都定義了各自不同的 IDL 格式,導致程序員的學習成本進一步上升。而 Web Service 嘗試建立業界標準,無賴標準規范復雜而效率偏低,否則 Thrift 等更高效的 RPC 框架就沒必要出現了。

IDL 是為了跨平臺語言實現 RPC 不得已的選擇,要解決更廣泛的問題自然導致了更復雜的方案。 而對于同一平臺內的 RPC 而言顯然沒必要搞個中間語言出來,例如 Java 原生的 RMI,這樣對于 Java 程序員而言顯得更直接簡單,降低使用的學習成本。

在上文進一步拆解了組件并劃分了職責之后,下面就以在 Java 平臺實現該 RPC 框架概念模型為例,詳細分析下實現中需要考慮的因素。

導出

導出是指暴露遠程接口的意思,只有導出的接口可以供遠程調用,而未導出的接口則不能。 在 Java 中導出接口的代碼片段可能如下:

我們可以導出整個接口,也可以更細粒度一點只導出接口中的某些方法,如下:

Java 中還有一種比較特殊的調用就是多態,也就是一個接口可能有多個實現,那么遠程調用時到底調用哪個?這個本地調用的語義是通過 JVM 提供的引用多態性隱式實現的,那么對于 RPC 來說跨進程的調用就沒法隱式實現了。如果前面 DemoService 接口有 2 個實現,那么在導出接口時就需要特殊標記不同的實現,如下:

上面 demo2 是另一個實現,我們標記為 demo2 來導出,那么遠程調用時也需要傳遞該標記才能調用到正確的實現類,這樣就解決了多態調用的語義。

導入

導入相對于導出而言,客戶端代碼為了能夠發起調用必須要獲得遠程接口的方法或過程定義。目前,大部分跨語言平臺 RPC 框架采用根據 IDL 定義通過 code generator 去生成 User-stub 代碼,這種方式下實際導入的過程就是通過代碼生成器在編譯期完成的。我所使用過的一些跨語言平臺 RPC 框架如 CORBAR、WebService、ICE、Thrift 均是此類方式。

代碼生成的方式對跨語言平臺 RPC 框架而言是必然的選擇,而對于同一語言平臺的 RPC 則可以通過共享接口定義來實現。

在 Java 中導入接口的代碼片段可能如下:

在 Java 中 import 是關鍵字,所以代碼片段中我們用 refer 來表達導入接口的意思。 這里的導入方式本質也是一種代碼生成技術,只不過是在運行時生成,比靜態編譯期的代碼生成看起來更簡潔些。Java 里至少提供了兩種技術來提供動態代碼生成,一種是 JDK 動態代理,另外一種是字節碼生成。 動態代理相比字節碼生成使用起來更方便,但動態代理方式在性能上是要遜色于直接的字節碼生成的,而字節碼生成在代碼可讀性上要差很多。兩者權衡起來,作為一種底層通用框架,個人更傾向于選擇性能優先。

協議

協議指 RPC 調用在網絡傳輸中約定的數據封裝方式,包括三個部分:編解碼、消息頭 和 消息體。

編解碼

客戶端代理在發起調用前需要對調用信息進行編碼,這就要考慮需要編碼些什么信息并以什么格式傳輸到服務端才能讓服務端完成調用。 出于效率考慮,編碼的信息越少越好(傳輸數據少),編碼的規則越簡單越好(執行效率高)。

我們先看下需要編碼些什么信息:

調用編碼

1.接口方法

包括接口名、方法名

2.方法參數

包括參數類型、參數值

3.調用屬性

包括調用屬性信息,例如調用附加的隱式參數、調用超時時間等

返回編碼

1.返回結果

接口方法中定義的返回值

2.返回碼

異常返回碼

3.返回異常信息

調用異常信息

消息頭

除了以上這些必須的調用信息,我們可能還需要一些元信息以方便程序編解碼以及未來可能的擴展。這樣我們的編碼消息里面就分成了兩部分,一部分是元信息、另一部分是調用的必要信息。如果設計一種 RPC 協議消息的話,元信息我們把它放在協議消息頭中,而必要信息放在協議消息體中。下面給出一種概念上的 RPC 協議消息頭設計格式:

  • magic

協議魔數,為解碼設計

  • header size

協議頭長度,為擴展設計

  • version

協議版本,為兼容設計

  • st

消息體序列化類型

  • hb

心跳消息標記,為長連接傳輸層心跳設計

  • ow

單向消息標記,

  • rp

響應消息標記,不置位默認是請求消息

  • status code

響應消息狀態碼

  • reserved

為字節對齊保留

  • message id

消息 id

  • body size

消息體長度

消息體

消息體常采用序列化編碼,常見有以下序列化方式:

  • xml

如 webservie SOAP

  • json

如 JSON-RPC

  • binary

如 thrift; hession; kryo 等

格式確定后編解碼就簡單了,由于頭長度一定所以我們比較關心的就是消息體的序列化方式。 序列化我們關心三個方面:

  1. 效率:序列化和反序列化的效率,越快越好。
  2. 長度:序列化后的字節長度,越小越好。
  3. 兼容:序列化和反序列化的兼容性,接口參數對象若增加了字段,是否兼容。

上面這三點有時是魚與熊掌不可兼得,這里面涉及到具體的序列化庫實現細節,就不在本文進一步展開分析了。

傳輸

協議編碼之后,自然就是需要將編碼后的 RPC 請求消息傳輸到服務端,服務方執行后返回結果消息或確認消息給客戶端。RPC 的應用場景實質是一種可靠的請求應答消息流,這點和 HTTP 類似。因此選擇長連接方式的 TCP 協議會更高效,與 HTTP 不同的是在協議層面我們定義了每個消息的唯一 id,因此可以更容易的復用連接。

既然使用長連接,那么***個問題是到底客戶端和服務端之間需要多少根連接?實際上單連接和多連接在使用上沒有區別,對于數據傳輸量較小的應用類型,單連接基本足夠。單連接和多連接***的區別在于,每根連接都有自己私有的發送和接收緩沖區,因此大數據量傳輸時分散在不同的連接緩沖區會得到更好的吞吐效率。

所以,如果你的數據傳輸量不足以讓單連接的緩沖區一直處于飽和狀態的話,那么使用多連接并不會產生任何明顯的提升,反而會增加連接管理的開銷。‘

連接是由客戶端發起建立并維持的,如果客戶端和服務端之間是直連的,那么連接一般不會中斷(當然物理鏈路故障除外)。如果客戶端和服務端連接經過一些負載中轉設備,有可能連接一段時間不活躍時會被這些中間設備中斷。為了保持連接有必要定時為每個連接發送心跳數據以維持連接不中斷。心跳消息是 RPC 框架庫使用的內部消息,在前文協議頭結構中也有一個專門的心跳位,就是用來標記心跳消息的,它對業務應用透明。

執行

客戶端 stub 所做的事情僅僅是編碼消息并傳輸給服務方,而真正調用過程發生在服務端。服務端 stub 從前文的結構拆解中我們細分了 RpcProcessor 和 RpcInvoker 兩個組件,一個負責控制調用過程,一個負責真正調用。 這里我們還是以 Java 中實現這兩個組件為例來分析下它們到底需要做什么?

Java 中實現代碼的動態接口調用目前一般通過反射調用。除了原生 JDK 自帶的反射,一些第三方庫也提供了性能更優的反射調用,因此 RpcInvoker 就是封裝了反射調用的實現細節。

調用過程的控制需要考慮哪些因素,RpcProcessor 需要提供什么樣地調用控制服務呢?下面提出幾點以啟發思考:

1.效率提升

每個請求應該盡快被執行,因此我們不能每請求來再創建線程去執行,需要提供線程池服務。

2.資源隔離

當我們導出多個遠程接口時,如何避免單一接口調用占據所有線程資源,而引發其他接口執行阻塞。

3.超時控制

當某個接口執行緩慢,而客戶端已經超時放棄等待后,服務端的線程繼續執行此時顯得毫無意義。

異常

無論 RPC 怎樣努力把遠程調用偽裝的像本地調用,但它們依然有很大的不同點,而且有一些異常情況是在本地調用時絕對不會碰到的。在說異常處理之前,我們先比較下本地調用和 RPC 調用的一些差異:

  1. 本地調用一定會執行,而遠程調用則不一定,調用消息可能因為網絡原因并未發送到服務方。
  2. 本地調用只會拋出接口聲明的異常,而遠程調用還會跑出 RPC 框架運行時的其他異常。
  3. 本地調用和遠程調用的性能可能差距很大,這取決于 RPC 固有消耗所占的比重。

正是這些區別決定了使用 RPC 時需要更多考量。 當調用遠程接口拋出異常時,異常可能是一個業務異常,也可能是 RPC 框架拋出的運行時異常(如:網絡中斷等)。業務異常表明服務方已經執行了調用,可能因為某些原因導致未能正常執行,而 RPC 運行時異常則有可能服務方根本沒有執行,對調用方而言的異常處理策略自然需要區分。

由于 RPC 固有的消耗相對本地調用高出幾個數量級,本地調用的固有消耗是納秒級,而 RPC 的固有消耗是在毫秒級。那么對于過于輕量的計算任務就并不適合導出遠程接口由獨立的進程提供服務,只有花在計算任務上的時間遠遠高于 RPC 的固有消耗才值得導出為遠程接口提供服務。

總結

至此我們提出了一個 RPC 實現的概念框架,并詳細分析了需要考慮的一些實現細節。無論 RPC 的概念是如何優雅,但是“草叢中依然有幾條蛇隱藏著”,只有深刻理解了 RPC 的本質,才能更好地應用。

看到這里的同學也許會想按這個概念模型和實現解析真得能開發實現一個 RPC 框架庫么?這個問題我能肯定的回答,真得可以。因為我就按這個模型開發實現了一個最小化的 RPC 框架庫來學習驗證,相關的代碼放在 Github 上,感興趣的同學可以自己去閱讀。這是我自己的一個實驗性質的學習驗證用開源項目,地址是 https://github.com/mindwind/craft-atom,其中的 craft-atom-rpc 即是按這個模型實現的微型 RPC 框架庫,代碼量相對工業級使用的 RPC 框架庫少的多,方便閱讀學習。

***,讀到這里的肯定都是好學不倦的同學,謝謝大家的時間,讓我寫作的意義更多了一點:)。

【本文是51CTO專欄作者胡峰的原創文章,轉載請聯系作者本人獲取授權】

戳這里,看該作者更多好文

責任編輯:武曉燕 來源: 瞬息之間
相關推薦

2025-03-27 08:15:38

2024-05-13 11:25:08

概念模型邏輯模型物理模型

2024-12-24 09:29:16

2009-12-28 15:18:29

WPF控件模型

2025-01-08 09:30:00

Meta大模型訓練

2023-12-29 08:33:17

2024-09-29 08:00:00

動態代理RPC架構微服務架構

2010-08-02 16:41:15

2010-06-29 16:53:08

2022-04-06 08:49:44

SSTKV存儲引擎

2016-08-23 17:21:51

UnixLinux重定向

2012-11-23 14:26:40

IBMdW

2017-02-24 17:24:16

Etcd架構分布式系統

2022-01-07 06:12:08

RPC框架限流

2010-07-19 08:39:14

Perl包

2010-09-26 11:31:03

DHCP服務

2017-02-21 13:16:49

微服務RPC技術

2010-03-02 09:38:16

Java熱替換

2014-04-10 18:00:10

Java8Java8教程

2025-10-09 05:11:00

I/O模型非阻塞socket
點贊
收藏

51CTO技術棧公眾號

日本亚洲精品在线观看| 日韩精品电影网| 日韩一级免费看| 婷婷色在线观看| 蜜臀国产一区二区三区在线播放| 久久最新资源网| 人妻换人妻a片爽麻豆| 欧美va视频| 亚洲福利电影网| 亚洲图片在线观看| 天堂在线资源网| 狠狠色综合播放一区二区| 97国产精品视频| 97精品在线播放| 一区二区美女| 欧美不卡123| 日韩一区二区三区久久| 密臀av在线播放| 亚洲乱码日产精品bd| 欧美日韩在线不卡一区| 亚洲精品久久久蜜桃动漫| 日韩激情一二三区| 97免费中文视频在线观看| 成人做爰视频网站| 国产精品最新| 日韩成人激情在线| 91人妻一区二区| 精品一区二区三区四区五区| 在线国产电影不卡| 六月丁香婷婷在线| 久草在线资源福利站| 亚洲免费在线电影| 日韩福利视频| 飘雪影院手机免费高清版在线观看| 国产在线一区二区| 国产精品久久久久久久久久东京 | 亚洲欧洲成人精品av97| 欧美凹凸一区二区三区视频| 乱精品一区字幕二区| 国产一区二区三区免费播放 | 精品久久亚洲| 欧美日韩高清一区二区| 爆乳熟妇一区二区三区霸乳| 在线视频超级| 欧美日韩亚洲一区二区| 丝袜人妻一区二区三区| 欧美xxxx免费虐| 亚洲欧美日韩国产综合| 在线综合视频网站| 天堂地址在线www| 国产精品国产a级| 夜夜爽www精品| 日本在线免费播放| 国产精品白丝在线| 国产福利片一区二区| 国产色在线观看| 亚洲靠逼com| 黄色影视在线观看| 99视频免费在线观看| 樱花草国产18久久久久| av动漫在线免费观看| a篇片在线观看网站| 樱花影视一区二区| 国产欧美日韩网站| 女海盗2成人h版中文字幕| 都市激情亚洲色图| 一道本视频在线观看| 国产精品天堂蜜av在线播放 | 一区二区三区自拍| 亚洲国产精品影视| 毛片在线视频| 亚洲一区二三区| 九九爱精品视频| 美女18一级毛片一品久道久久综合| 一本到高清视频免费精品| 中国黄色片免费看| 国产一区二区三区精品在线观看| 日韩精品一区二区三区在线播放| 91超薄肉色丝袜交足高跟凉鞋| 荡女精品导航| 国产亚洲综合久久| 丝袜美腿小色网| 136国产福利精品导航网址| 4388成人网| 中文字幕有码视频| 国产成人精品亚洲777人妖| 国产一区二区三区高清视频| 国内精品在线视频| 亚洲精品自拍动漫在线| 男人和女人啪啪网站| 日本电影久久久| 精品国产精品一区二区夜夜嗨| 性少妇bbw张开| 一区二区三区国产精华| 91av在线影院| 99国产精品欲| 久久亚洲一级片| 中文字幕の友人北条麻妃| 欧产日产国产精品视频| 欧美剧在线免费观看网站 | 日韩电影不卡一区| 久久精品中文字幕| 九九九国产视频| 久色婷婷小香蕉久久| 精品一卡二卡三卡四卡日本乱码| 日本在线看片免费人成视1000| 午夜国产不卡在线观看视频| 一区二区三区四区毛片| 亚洲成a人片77777在线播放 | 亚洲一区二区三区免费看| 日韩成人伦理| 欧美精品v国产精品v日韩精品| 日本xxxx裸体xxxx| 国内揄拍国内精品久久| 国产欧美一区二区三区久久| 青青草在线免费视频| 亚洲一区在线观看网站| 中日韩av在线播放| 欧美午夜精品一区二区三区电影| 午夜精品三级视频福利| 国产男男gay体育生白袜| 91蜜桃在线免费视频| 国产精品69久久久| 国产一区二区三区黄网站| 中文字幕精品国产| 亚洲欧美日韩激情| 91日韩精品一区| 可以在线看的av网站| 秋霞一区二区三区| 久久精品视频免费播放| 中文在线字幕av| 国产亚洲欧美日韩日本| 浮妇高潮喷白浆视频| 高潮久久久久久久久久久久久久| 精品国偷自产在线| 亚洲无码精品在线观看| 国产亚洲美州欧州综合国| 日本免费黄视频| 精品一区二区男人吃奶| 久久久久女教师免费一区| 国产精品欧美激情在线| 亚洲欧洲精品天堂一级| 亚洲欧美自拍另类日韩| 欧美日韩精品综合| 国产伦精品一区二区三区在线| 亚洲天堂中文字幕在线| 国产欧美一区视频| 国产aaaaa毛片| 精品欧美久久| 国产精品视频一| 99se视频在线观看| 欧美日韩黄视频| 成人信息集中地| 精品制服美女丁香| 日韩video| 亚洲一区二区电影| 久久免费精品视频| 午夜福利理论片在线观看| 黑人狂躁日本妞一区二区三区 | 国产精品无人区| 亚洲欧美另类动漫| 欧美hentaied在线观看| 成人天堂噜噜噜| 欧美另类tv| 日韩成人av在线播放| 免费精品一区二区| 亚洲丝袜制服诱惑| 又色又爽又黄18网站| 99国内精品| 日韩色妇久久av| 亚洲欧洲专区| 久久久久久久久久av| 色播色播色播色播色播在线| 欧美三级中文字| 少妇久久久久久被弄高潮| kk眼镜猥琐国模调教系列一区二区| 亚洲中文字幕无码专区| 欧美日韩第一| 亚洲va久久久噜噜噜| 蜜桃视频在线观看播放| 有码中文亚洲精品| 亚洲精品一区二区口爆| 色欧美88888久久久久久影院| 国产又黄又粗又猛又爽的| 国产成人av电影在线观看| 国产精品无码专区av在线播放 | 久久亚洲国产精品| 手机在线观看免费av| 欧美在线观看视频在线| 久草成人在线视频| 国产日产精品1区| 久久久久中文字幕亚洲精品| 久久国产毛片| 嫩草影院中文字幕| 精品大片一区二区| 操一操视频一区| 欧美暴力调教| 97色伦亚洲国产| 色影院视频在线| 日韩av在线最新| 国产色片在线观看| 色婷婷综合中文久久一本| 欧美成人国产精品高潮| 国产亚洲一区二区在线观看| 中文字幕第九页| 裸体在线国模精品偷拍| 777久久久精品一区二区三区| 香蕉综合视频| 偷拍视频一区二区| 另类春色校园亚洲| 444亚洲人体| 欧美日韩va| 国产成人97精品免费看片| www在线观看黄色| 日韩中文字幕国产| 激情在线视频| 日韩精品中文字幕久久臀| www精品国产| 欧美日韩一区二区三区四区五区| 日韩欧美成人一区二区三区| 一区二区三区久久久| 成人欧美一区二区三区黑人一 | 国产日韩欧美在线观看视频| 国产亚洲精品资源在线26u| 国产性生活毛片| 国产成+人+日韩+欧美+亚洲| 激情久久综合网| 蜜桃久久精品一区二区| 熟女少妇在线视频播放| 激情久久久久久| 国产一级做a爰片久久毛片男| 91精品秘密在线观看| 午夜精品一区二区在线观看| 国产麻豆一区二区三区精品视频| 久久艳妇乳肉豪妇荡乳av| 激情小说一区| 国产一区二区三区高清| 99re热精品视频| 国产精品久久久久久久免费大片| 日本精品在线播放| 亚洲一区亚洲二区| 日本超碰一区二区| 国产高清自拍99| 99久久免费精品国产72精品九九 | 欧洲亚洲妇女av| 原纱央莉成人av片| 国产成人a亚洲精品| 欧美xxx性| 国产精品久久在线观看| 国产精品黄色片| 国产在线观看一区二区三区| 999色成人| 99在线视频播放| 久久黄色影视| 欧美大陆一区二区| 欧美日韩一二三四| 一本一道久久a久久精品综合| 天天射成人网| 在线观看av的网址| 欧美三级第一页| 国产精品999视频| 老司机一区二区三区| 黄色在线视频网| 国产在线精品一区二区| 精品国产aⅴ一区二区三区东京热| 成人美女在线视频| 波多野结衣 在线| 国产精品日日摸夜夜摸av| 欧美手机在线观看| 亚洲一区二区三区四区五区中文 | 波多野结衣家庭教师在线观看| 国产精品对白交换视频| 国产十六处破外女视频| 亚洲二区视频在线| 天堂免费在线视频| 日韩一区二区免费高清| 日本毛片在线观看| 亚洲视频网站在线观看| 久做在线视频免费观看| 97国产精品视频| 成人免费黄色| 国产精品免费一区二区三区| 久久av电影| 成人免费看片视频在线观看| 亚洲主播在线| 天堂中文av在线| heyzo一本久久综合| 亚洲第一视频区| 亚洲国产精品尤物yw在线观看| 亚洲天堂一区在线| 91麻豆精品91久久久久久清纯| 五月天激情婷婷| 精品国产欧美一区二区三区成人| 狠狠躁少妇一区二区三区| 成人免费淫片视频软件| 麻豆一区二区| 中文字幕色一区二区| 亚洲欧美日韩综合国产aⅴ| 日韩a一级欧美一级| 91欧美激情一区二区三区成人| 久久成人小视频| 色综合视频在线观看| 午夜精品无码一区二区三区| 亚洲最新av在线| 男人天堂视频在线观看| 91亚洲永久免费精品| 经典一区二区| 国产av国片精品| 国产剧情av麻豆香蕉精品| 精品欧美一区二区久久久| 亚洲一区二区三区精品在线| 亚洲午夜精品久久久| 亚洲精品中文字幕有码专区| 日韩免费影院| 亚洲一区二区三区xxx视频| 精品久久影视| 久久网站免费视频| 成人免费高清在线| 人妻久久一区二区| 欧美日本高清视频在线观看| 日本中文字幕一区二区有码在线| 欧美精品生活片| 四虎影视国产精品| 日韩精品久久久毛片一区二区| 在线视频精品| 精品国产人妻一区二区三区| 一区二区三区国产精品| 国产麻豆91视频| 中文字幕亚洲字幕| 成人日韩在线| 欧美日韩国产三区| 国产情侣一区| 99久久国产精| 亚洲成人综合网站| 亚洲毛片欧洲毛片国产一品色| 久久九九精品99国产精品| 欧美男男gaygay1069| 亚洲精品不卡| 久久精品国产999大香线蕉| 久操视频在线观看免费| 欧美在线影院一区二区| www视频在线观看免费| 国产91免费观看| 欧美禁忌电影| 538任你躁在线精品免费| 亚洲国产成人一区二区三区| 中文字幕在线2018| 视频在线观看99| 亚洲青青一区| 国产情侣第一页| 成人18视频日本| 国产情侣在线视频| 亚洲精品视频在线播放| japanese23hdxxxx日韩| 欧美一级片免费观看| 秋霞电影网一区二区| 精品丰满少妇一区二区三区| 欧美天天综合网| 黄页视频在线播放| 成人黄色片视频网站| 精品999日本| 亚洲精品成人无码熟妇在线| 欧美伊人久久久久久久久影院 | 欧美日韩一区二区三区69堂| 亚洲欧洲性图库| 精品久久久中文字幕人妻| 国产最新精品视频| 免费成人结看片| 91插插插插插插插插| 亚洲激情校园春色| 国产精品国产高清国产| 国产精品www| 在线中文字幕亚洲| 中文字幕在线免费看线人| 欧美亚洲一区三区| 中文字幕伦理免费在线视频 | 精品国内自产拍在线观看视频| xx欧美撒尿嘘撒尿xx| 亚洲精品久久嫩草网站秘色| 午夜影院免费体验区| 国产精品678| 一区二区电影在线观看| 玖玖爱在线观看| 制服视频三区第一页精品| 国产乱码精品一区二三赶尸艳谈| 日本一区免费观看| 国产精品一级在线| 国产又粗又爽视频| 久久国产天堂福利天堂| 四虎5151久久欧美毛片| 欧美成人手机在线视频| 欧美午夜无遮挡| 超碰在线无需免费| 欧美日韩精品久久久免费观看| 精品亚洲国内自在自线福利| 日本一区二区三区四区五区| 日韩中文字幕第一页| 亚洲高清极品| 少妇熟女视频一区二区三区| 在线观看日韩av先锋影音电影院|