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

Apache Flink 漫談系列 - PyFlink核心技術揭秘

原創
人工智能 新聞
Apache Flink 是一個在無界和有界數據流上進行有狀態計算的分布式框架,在實時數據倉庫,機器學習,數據分析,事件驅動等場景廣泛應用。

圖片

大家好,非常高興在今天的峰會能與大家一起分享Apache PyFlink的核心技術部分。

圖片

首先,還是簡單的自我介紹一下,我是孫金城,花名 金竹,來自阿里巴巴,從2016年開始一直投入在開源建設中,目前是Apache Flink PMC成員,Apache Beam Committer和Apache IoTDB的PMC成員。同時也是Apache 軟件基金會的成員,Apache Member。平時也喜歡寫一些技術類博客和錄制一下視頻課程,也歡迎大家關注我的公眾號。

圖片

今天我們有4個部分的內容分享,首先我們快速了解一下PyFlink的使命愿景,然后重點介紹PyFlink的核心技術點,最后是和大家快速介紹PyFlink的未來規劃和現有的應用案例。那么我們開始今天的第一部分,PyFlink的使命愿景。

圖片

首先,Apache Flink 是一個有狀態的分布式流式計算框架。可以作用在有限和無限的數據集合之上。

那么業界對有限和無限數據集合上進行流式計算處理,有2種典型的架構,一個是Micro-Batching的模式,也就是將流看成是批的特例。那么另一種就是Apache Flink的架構模式,純流的架構模式,將批看成是流的特例。純流的設計將計算的延時做到了極致。

圖片

那么Flink這種分布式亞秒級延時的能力如何暴露給用戶呢?Flink提供了SQL,DataStream和ProcessFunction多層API供用戶選擇,但是非常遺憾的是只能提供給Java用戶群體。

那么,如果將Flink的能力進行放大,面向更多的用戶群體將是一件非常有意義的事情,那么如何在在Flink上進行多語言的支持呢?增加哪些語言的支持呢?

圖片

我們在進行PyFlink的工作之前進行了一些調研,我們發現Python語言在2020年的活躍程度超過了Java語言,并且是一個持續上升的趨勢。

圖片

那么我們再進一步了解,為什么Python語言如此備受關注,大家都利用Python語言完成怎樣的工作呢?帶著這些問題,隨著AI的崛起,Python不僅僅廣泛應用在數據分析和web開發領域,更多的也在AI/機器學習領域也有廣泛應用。更有趣的一件事是,連公路巡警的愛好都變成了Python編程,8/9歲的小孩也在用Python做趣味游戲。這足以見證Python的受歡迎程度。所以將Python作為Flink多語言支持最重要的開發語言。

圖片

Python非常受歡迎,并且Python有非常成熟的生態發展,但是這里有一個典型的問題,那就是這些生態庫大多是單機模式,在大數據時代的今天,Python生態面臨的一個典型問題就是:

如何支持海量數據的處理,如何提供分布式能力?

圖片

所以,面對Flink能力需要面向更多的用戶群體,Python又是最受歡迎的語言,Python就成為了Flink多語言支持的第一個語言。同時面對Python語言的分布式能力的匱乏,PyFlink的使命也是要將Python生態具備分布處理能力。所以,Pyflink的使命就是Flink能力輸出到Python用戶,并令Python生態具備分布式化能力。

圖片

好的,接下來我們看看PyFlink如何完成自己的使命,有哪些核心的技術細節。

圖片

首先,Flink能力輸出到Python用戶最核心問題顯而易見是Python VM和Java VM的握手,他們之間要建立通訊,這是PyFlink首要解決的問題。

圖片

面對PVM和JVM通訊問題,我們選擇了Py4J,在PythonVM啟動一個Gateway,并且Java VM啟動一個Gateway Server用于接受Python的請求,同時在Python API里面提供和Java API一樣的對象,比如 TableENV, Table,等等。這樣Python在寫Python API的時候本質是在調用Java API,同時還有作業部署問題,我們可以用Python命令,Python shell和CLI等多種方式進行作業提交。

圖片

那么Py4J和JVM交互的原理是什么呢?其實最核心的機制是在Python端每創建一個對象,都會對應的在Java端創建一個Java對象,并生成一個對象ID,Java端利用Map保存對象ID和對象。同時將對象ID返回Python端,Python端基于對象ID和方法參數進行操作本質上都是在操作Java對象。

圖片那么基于這樣的架構有怎樣的優勢呢?第一個就是簡單,并確保Python API語義和Java API的一致性,第二點,Python 作業可以達到和Java一樣的極致性能,在剛剛結束的阿里雙11狂歡節中,創造了峰值40億的處理能力。

圖片

OK,在完成了現有Flink功能向Python用戶的輸出之后,接下來我們繼續探討,如何將Python生態功能引入Flink中,進而將Python 功能分布式化。如何達成?結合現有Flink Table API的現狀和現有Python類庫的特點,我們可以對現有所有的Python類庫功能視為 用戶自定義函數(UDF),集成到Flink中。這樣我們就找到了集成Python生態到Flink中的手段是將其視為UDF,那么集成的核心問題是什么?沒錯,那就是Python UDF的執行問題。好,我們針對這個核心問題我們如何處理呢?

圖片

解決Python UDF執行問題可不僅僅是VM之間通訊的問題了,它涉及到Python執行環境的管理,業務數據在Java和Python之間的解析,Flink State Backend能力向Python的輸出,Python UDF執行的監控等等,是一個非常復雜的問題。面對這樣復雜的問題,我們選擇了統一編程模型Apache Beam,Beam為了解決多語言和多引擎支持問題高度抽象了一個叫 Portability Framework 的架構,如下圖,Beam目前可以支持Java/Go/Python等多種語言,其中圖下方 Beam Fu Runners 和 Execution之間就解決了 引擎和UDF執行環境的問題。其核心是對利用Protobuf進行數據結構抽象,利用gRPC協議進行通訊,同時封裝了核心的gRPC 服務。所以這時候Beam更像是一只螢火蟲,照亮了PyFlink解決UDF執行問題之路。我們接下來看看Beam到底提供了哪些gRPC服務。

圖片

如圖 Runner部分是Java的算子執行,SDK Worker部分是Python的執行環境,Beam已經抽象Control/Data/State/Logging等服務。并這些服務已經在Beam的Flink runner上穩定高效的運行了很久了。所以在PyFlink UDF執行上面我們可以站在巨人的肩膀上了:),這里我們發現Apache Beam 在API層面和在UDF的執行層面都有解決方案,而PyFlink在API層面采用了Py4J解決VM通訊問題,在UDF執行需求上采用了Beam的Protability Framework解決UDF執行環境問題。這也表明了PyFlink在技術選型上嚴格遵循以最小的代價達成既定目標的原則,在技術選型上永遠會選擇最合適的,最符合PyFlink長期發展的技術架構。

圖片

好,那么現在我們回答,Flink如何支持多語言呢?

在API層面,其他語言要搞定algin現有的Java語言API。

在語言的執行環境問題上面,Flink可以重用Beam提供的基礎設施。換句話說,我們可以在Flink runner和fnapi級別上輕松地重用基本服務和數據結構。這將使Flink很容易支持多種語言。

下面的內容我們一起看看PyFlink的UDF架構設計。

圖片

K,我們再整體看一下 PyFlink UDF的整體架構。在UDF的架構中我們我既要考慮Java VM和Python VM的通訊問題,又要考慮在編譯階段和在運行階段的不同需求。

圖中我們以綠色表示Java VM的行為,藍色表示Python VM的行為。

首先我們看看編譯階段,也就是local的設計,在local的設計是純API的mapping調用,我們仍然要過Py4J來解決通訊問題。也就是如圖Python每執行一個API就會同步的調用Java所對應的API。對UDF的支持上,需要添加UDF注冊的API,register_function,但僅僅是注冊還不夠,用戶在自定義Python UDF的時候往往會依賴一些三方庫,

所以我們還需要增加添加依賴的方法,那就是一系列的add方法,比如add_Python_file()。

在編寫Python作業的同時,Java API也會同時被調用在提交作業之前,Java端會構建.JobGraph。然后通過CLI等多種方式將作業提交到集群進行運行。

我們再來看看運行時Python和Java的不同分工情況,首先在Java端與普通Java作業一樣,JobMaster將作業分配給TaskManger,TaskManager會執行一個個Task,task里面就涉及到了Java和Python的算子執行。

在Python UDF的算子中我們會設計各種gRPC服務來完成Java VM和Python VM的各種通訊,比如 DataService 完成業務數據通訊,StateService完成Python UDF對Java Statebackend的調用,當然還有Logging和Metrics等其他服務。這些服務都是基于Beam的Fn API來構建的,最終在Python的Worker里面運行用戶的UDF,運行結束之后再利用對應的gRPC服務將結果返回給Java端的PythonUDF算子。

當然Python的worker不僅僅是Process模式,可以是Docker模式甚至是External的服務集群。這種擴展機制,為后面PyFlink與Python生態的其他框架集成打下了堅實的基礎。

圖片

這里最重要的是如何使用beam的基礎設施來執行Python UDF。我們來看看pyflink如何集成Beam的可移植性框架來執行Python UDF。一個場景的場景是對輸入數據執行一系列轉換并將結果寫入另一個外部存儲系統。我們知道Flink是用Java 開發的,但是,用戶定義的轉換邏輯是Python開發的。如圖示例,假設ParDo使用了Python UDF,在Beam中引入了一個ExecutableStage,它包含了用戶定義的Python函數的所有必要信息,如:輸入/輸出數據類型、用戶定義函數的有效負載、用戶定義函數中使用的狀態和定時器等等。同時,Beam還提供了一個Java庫,可用于管理特定語言的執行環境。”forStage()“將根據ExecutableStage中定義的信息生成執行用戶定義函數所需的進程,就是SDK harness部分,這樣建立runner與SDK Harness之間就建立起了通訊連接。

Beam的SDK harness支持執行多種功能,例如ParDo、Flatten等;?不同的函數有不同的執行模式,因此SDK harness定義了一個特定的操作類來執行它。但是我們怎樣才能清楚地定義beam中每個函數的執行邏輯呢?Beam提供了非常靈活的插件機制,也就是為每種類型的函數定義一個URN,比如Input/output/parDo等。這樣的插件機制也為Flink集成Beam框架提供了便利途徑。

圖片

那么在PyFlink中使用Python SDK Harness的作原理如下:?

在啟動階段,Python SDK Harness將為所有內置操作建立URN和操作映射。

在處理新包的初始化階段,運行程序將把URN和函數一起發送到SDK Harness。SDK Harness可以根據給定的URN構造相應的操作。然后使用該操作來執行輸入的數據和對應的用戶定義函數邏輯。

我們看到如圖我們定義各種URN,包括input/output,coder等等。

圖片

OK,那么注冊URN也非常簡單,就是我們添加了一些用于創建自定義操作和Coder的函數。這些函數用Beam的python sdk工具包中定義的decorator進行裝飾。decorator包含兩個參數:URN和一個基于protobuf的自定義參數。

圖片

OK,支持了Python UDF之后,我們還將Pandas的與PyFlink進行了集成,我們可以非常便利的在PyFlink中定義PandasUDF,同時我們還提供了frompandas和topandas的api支持Flink和Pandas間的操作轉換。

同時我們在udf的執行性能上也不斷的優化,在1.11的版本相對于1.10有30倍的性能提升。

OK,接下來我們快速看看PyFlink的未來規劃。

圖片

PyFlink的發展始終要以本心驅動,我們要圍繞將現有Flink功能輸出到Python用戶,將Python生態功能集成到Flink當中為目標。

首先解決Python VM和Java VM的通訊問題,

然后將現有的Table API功能暴露給Python用戶,提供Python Table API,

這也就是Flink 1.9中所進行的工作,

接下來我們要為將Python功能集成到Flink做準備就是集成Apache Beam,提供Python UDF的執行環境,

并增加Python 對其他類庫依賴的管理功能,

為用戶提供User-defined-Funciton的接口定義,支持Python UDF,

這就是Flink 1.10所做的工作。

為了進一步擴大Python生態的分布式功能,PyFlink將提供Pandas的Series和DataFram的支持,也就是用戶可以在PyFlink中直接使用Pandas的UDF。

同時為增強用戶的易用性,讓用戶有更多的方式使用PyFlink,后續增加在Sql Client中使用Python UDF。

面對Python用戶的機器學習問題,增加Python 的 ML pipeline API。

監控Python UDF的執行情況對,對實際的生產業務非常關鍵,所以PyFlink會增加Python UDF的Metric管理. 這就是在Flink1.11中的工作。

同時我們還需要對性能不斷有優化,對Datastream和已經k8s等提供支持,這些在PyFlink 1.12中提供給大家。

后續還會不斷將Flink現有功能推向Python生態,將Python 生態的強大功能不斷集成到Flink當中,進而完成Python生態分布化的初衷。

圖片

當然,PyFlink同樣會注重生態的集成,如與Zeppelin,jupyter,PyAlink等集成工作的推進。

圖片

最后,快速看一下PyFlink的應用案例。

圖片

PyFlink可以應用在事件驅動/數據分析/ETL/機器學習等多種場景中。目前也有很多的投產用戶。

比如,比特幣大陸,聚美優品等等。目前PyFlink已經趨于成熟,非常適合大家選擇Flink快速構建分布式計算系統的切入開發語言。

圖片

目前PyFlink功能趨于完備,當然也會有更多的工作要做,但無論如何,我相信后續會慢慢成熟起來!我將會在2020年12月份開始將精力投入到IoT領域,開啟一段新的探索~

作者介紹

孫金城,51CTO社區編輯,Apache Flink PMC 成員,Apache Beam Committer,Apache IoTDB PMC 成員,ALC Beijing 成員,Apache ShenYu 導師,Apache 軟件基金會成員。關注技術領域流計算和時序數據存儲。

責任編輯:張燕妮 來源: 孫金城
相關推薦

2016-11-22 17:05:54

Apache Flin大數據Flink

2018-05-16 11:05:49

ApacheFlink數據流

2022-06-10 17:26:07

數據集計算

2018-09-26 08:44:22

Apache Flin流計算計算模式

2018-09-26 07:50:52

Apache Flin流計算計算模式

2018-10-16 08:54:35

Apache Flin流計算State

2018-10-09 10:55:52

Apache FlinWatermark流計算

2022-07-13 12:53:59

數據存儲

2018-11-14 09:01:23

Apache FlinSQL代碼

2018-10-22 21:43:39

Apache Flin流計算Fault Toler

2018-11-20 07:59:43

Apache Flin JOIN算子代碼

2018-11-29 09:01:26

Apache FlinJOIN代碼

2019-01-03 10:17:53

Apache FlinTable API代碼

2018-12-11 17:28:22

Apache FlinJOIN代碼

2022-07-13 13:03:29

流計算亂序

2016-11-15 14:33:05

Flink大數據

2018-11-07 08:48:31

Apache Flin持續查詢流計算

2019-01-15 08:50:12

Apache FlinKafka分布式

2018-10-30 14:08:45

Apache Flin流表對偶duality

2020-04-09 11:08:30

PyFlinkJAR依賴
點贊
收藏

51CTO技術棧公眾號

国产欧美日韩亚洲精品| 日韩成人黄色av| 4444亚洲人成无码网在线观看| www.午夜激情| 亚洲欧美日韩在线观看a三区| 亚洲欧美在线免费| 亚洲高清视频免费| 免费h在线看| 国产精品久久久久久亚洲伦| 动漫3d精品一区二区三区| 天天干天天干天天| 91精品秘密在线观看| 亚洲激情 国产| 亚洲最大天堂网| 天堂中文在线播放| 亚洲伦理在线精品| 欧美一区二区三区四区在线观看地址| 国产一区二区三区在线观看| 国产日韩欧美一区| 久久精视频免费在线久久完整在线看| 性生活在线视频| 天堂久久午夜av| 亚洲一区二区在线免费看| 日韩免费av电影| 俄罗斯嫩小性bbwbbw| 久久99国产精品麻豆| 91黑丝高跟在线| 五月天色婷婷丁香| 精品产国自在拍| 精品成人一区二区三区四区| 亚洲欧美日韩精品一区| 在线男人天堂| 亚洲另类自拍| 在线播放日韩精品| 日韩网站在线播放| 亚洲精品黑牛一区二区三区| 欧美日韩国产中文| 国产精品人人爽人人爽| 天堂8中文在线最新版在线| 亚洲激情av在线| 亚洲欧洲精品一区二区| 涩爱av在线播放一区二区| 国产不卡在线播放| 成人精品久久久| 怡春院在线视频| 日韩精品视频网| 奇米四色中文综合久久| 日韩免费不卡视频| 亚洲午夜91| 久久99精品久久久久久琪琪| 肉色超薄丝袜脚交69xx图片| 成人精品中文字幕| 在线看福利67194| 三年中国中文观看免费播放| 亚洲婷婷影院| 亚洲精品一区二区久| 99久久免费看精品国产一区| 国产精品欧美大片| 精品99一区二区| 午夜影院福利社| 成人台湾亚洲精品一区二区| 精品人在线二区三区| 不许穿内裤随时挨c调教h苏绵| 玖玖精品一区| 欧美成人欧美edvon| 伊人av在线播放| 精品av导航| 日韩国产高清污视频在线观看| 在线精品一区二区三区| 亚洲免费专区| 在线看国产精品| 久草福利资源在线| 综合久久一区| 久久久久久久香蕉网| 99久在线精品99re8热| 先锋影音国产一区| 国产精品美女久久久久久免费| 中文字幕在线一| 国产伦理精品不卡| 精品婷婷色一区二区三区蜜桃| 头脑特工队2免费完整版在线观看| 91麻豆文化传媒在线观看| 欧美激情第六页| 日韩理伦片在线| 一区二区成人在线视频| 97视频久久久| av一区在线播放| 欧美一区二区成人| 亚洲精品理论片| 97精品国产福利一区二区三区| 操91在线视频| 久久一区二区三区视频| 免费在线欧美视频| 动漫一区二区在线| 成人精品一区二区三区校园激情| 亚洲欧美国产毛片在线| 亚洲精品国产精华液| 久久亚洲一区二区三区四区五区高| 成人在线观看小视频| 女人香蕉久久**毛片精品| 国产+成+人+亚洲欧洲| 精品国产xxx| 激情成人午夜视频| 精品久久sese| 黄视频网站在线| 欧美日韩一区二区在线播放| 午夜av中文字幕| 亚洲国产中文在线二区三区免| 日韩高清免费在线| 丝袜 亚洲 另类 欧美 重口| 亚洲一区激情| 99国产在线观看| av在线电影网| 亚洲第一成人在线| 网站在线你懂的| 蜜臀91精品国产高清在线观看| 久久久国产成人精品| 青青国产在线观看| 国产成人精品综合在线观看 | 亚洲午夜精品福利| 1区2区3区在线| 69精品人人人人| 国产精品免费无码| 中文高清一区| 999在线观看免费大全电视剧| 国产在线观看黄| 五月婷婷激情综合| 91精品人妻一区二区三区四区| 日韩aaaa| 国产精品福利小视频| 同心难改在线观看| 亚洲国产视频在线| www.色.com| 亚洲午夜精品一区二区国产| 国产精品色悠悠| 精品乱码一区二区三四区视频| 亚洲成人一区二区在线观看| 女教师高潮黄又色视频| 天堂网在线观看国产精品| 国产精品视频区| 国产在线观看高清视频| 在线影院国内精品| 成人午夜福利一区二区| 亚洲每日更新| 精品国产中文字幕| 校园春色亚洲| 日韩美女av在线| 亚洲永久精品在线观看| av成人动漫在线观看| 人妻av中文系列| 国产劲爆久久| 777国产偷窥盗摄精品视频| 国产综合无码一区二区色蜜蜜| 伊人婷婷欧美激情| 国产高潮失禁喷水爽到抽搐| 亚洲国产黄色| 激情伦成人综合小说| 男人天堂视频在线观看| 日韩成人在线视频| 日韩精品一区二区亚洲av| 久久久久久97三级| 男人插女人下面免费视频| 精品免费在线| 91九色国产社区在线观看| 韩国中文字幕在线| 欧美va亚洲va在线观看蝴蝶网| 国产一级aa大片毛片| 成人免费看视频| 国产美女无遮挡网站| 伊甸园亚洲一区| 国产美女精彩久久| 影音先锋在线视频| 日韩国产在线看| 国产成人麻豆免费观看| 国产精品久久久久天堂| 中文字幕久久久久久久| 一本色道久久精品| 色涩成人影视在线播放| 曰本一区二区| 97在线视频精品| 国产日产精品久久久久久婷婷| 欧美日韩aaa| 亚洲国产精品午夜在线观看| 久久九九国产精品| 韩国一区二区在线播放| 91久久综合| 亚洲精品tv久久久久久久久| 国产激情一区| 91大神福利视频在线| 一级毛片视频在线| 欧美电视剧在线看免费| 男人天堂av在线播放| 国产精品第一页第二页第三页| 伊人av在线播放| 日韩精品电影在线| 成人在线免费观看视频网站| 最新精品国偷自产在线| 成人激情在线播放| 涩涩在线视频| 久久久久www| 日本韩国精品一区二区| 欧美一区二区三区视频免费播放| 在线观看中文字幕视频| 亚洲六月丁香色婷婷综合久久| 添女人荫蒂视频| 中文字幕人妻一区二区三区| 欧美国产偷国产精品三区| av观看久久| 精品成人av| 性亚洲最疯狂xxxx高清| 欧美日本一道| 亚洲欧美日韩一区二区三区在线| 国产高清不卡视频| 欧美日韩精品一区二区三区| 日韩三级一区二区三区| 亚洲男人的天堂av| 亚洲一区二区自偷自拍 | 亚洲午夜影视影院在线观看| 美国黄色特级片| 久久综合九色综合久久久精品综合| 在线a免费观看| 蜜臀av亚洲一区中文字幕| 我的公把我弄高潮了视频| 中文无码久久精品| 亚洲成人午夜在线| 欧美极品在线观看| 久久久水蜜桃| 美女视频免费精品| av在线不卡观看| 精品国产一级| 成人黄色影片在线| 日本成人福利| 国产福利精品视频| 亚洲欧美小说色综合小说一区| 欧美激情视频在线| wwwav在线| 免费97视频在线精品国自产拍| 色哟哟免费在线观看| 中文字幕成人精品久久不卡| 国产三级电影在线| 亚洲欧美中文日韩在线| 你懂得在线网址| 国产视频精品一区二区三区| 亚洲精品国产av| 欧美成人性战久久| 免费国产精品视频| 精品乱人伦小说| 少妇av一区二区| 日韩精品久久久久久久玫瑰园| 天堂网在线播放| 日韩电视剧免费观看网站| 亚州男人的天堂| 精品丝袜一区二区三区| 青青操视频在线| 国产一区二区三区久久精品| 国产免费永久在线观看| 亚洲最新av在线| 91免费在线| 久久天堂av综合合色| 在线观看a级片| 久久久亚洲成人| 天堂中文在线播放| 国产精品免费小视频| 日韩专区视频| 69堂成人精品视频免费| 香蕉成人app| 精品国产免费人成电影在线观... 精品国产免费久久久久久尖叫 | 亚洲国产精品综合久久久| 亚洲国产精品视频一区| 99视频精品全国免费| 国产在线无码精品| 99精品热视频只有精品10| 欧美 日韩 国产一区| 国产精品久久久久毛片大屁完整版 | 超碰在线亚洲| 韩国成人一区| 精品九九在线| 9999在线观看| 亚洲高清激情| 91av俱乐部| 国产一区二区三区四| 97人妻精品一区二区三区免费| 99久久精品99国产精品 | 综合久久久久久久| 久久免费播放视频| 欧洲生活片亚洲生活在线观看| 国产精品免费无遮挡| 亚洲成人精品久久| 不卡在线视频| 欧美激情乱人伦| 欧美aaa大片视频一二区| 3d动漫啪啪精品一区二区免费 | 亚洲第一二三四五区| 国产一区精品| 欧美国产第一页| 精品亚洲美女网站| 高清视频在线观看一区| 欧美人与牛zoz0性行为| 精品人妻大屁股白浆无码| 久久综合激情| 任你躁av一区二区三区| 国产精品天美传媒沈樵| 国产对白videos麻豆高潮| 7777精品久久久大香线蕉| 亚洲人午夜射精精品日韩| 日韩视频永久免费观看| 一区二区三区四区日本视频| 亚洲综合日韩在线| 欧美日韩激情| 日韩在线综合网| 国产精品888| 日韩欧美黄色网址| 岛国视频午夜一区免费在线观看| 国产精品久久久久久久一区二区| 日韩经典中文字幕| 丁香花在线影院| 成人性生交大片免费观看嘿嘿视频| 最新亚洲精品| 久久久久久久久久网| 老司机午夜精品99久久| aa片在线观看视频在线播放| 一区二区三区四区不卡视频| 亚洲一级片免费看| 亚洲老头同性xxxxx| av中文字幕在线看| 91精品国产综合久久久久久丝袜| 成人一区不卡| 青青在线免费观看视频| 99精品视频中文字幕| 久草国产在线视频| 欧美一级免费大片| 国产美女在线观看| 成人免费直播live| 日韩欧美午夜| 欧美三级理论片| 国产欧美日韩卡一| 国产99免费视频| 亚洲精品视频二区| 小早川怜子影音先锋在线观看| 国产偷国产偷亚洲高清97cao| 欧美日本一区二区高清播放视频| 污视频网站观看| 国产精品每日更新在线播放网址| 无码任你躁久久久久久久| 亚洲女同性videos| 欧美18av| 色噜噜狠狠色综合网| 爽好多水快深点欧美视频| 久久精品国产亚洲av久| 一本大道久久精品懂色aⅴ| 深夜福利视频在线免费观看| 97色在线观看| 三级精品视频| 国产免费人做人爱午夜视频| 久久精品欧美一区二区三区麻豆| 91在线视频免费播放| 一区二区三欧美| 日韩午夜电影免费看| 大桥未久一区二区三区| 国产精品12区| 国产亚洲精品久久久久久无几年桃 | 亚洲欧美国产不卡| 日本aⅴ精品一区二区三区| 快灬快灬一下爽蜜桃在线观看| 欧美日韩亚洲国产综合| 操你啦在线视频| 国产精品初高中精品久久| 日韩一级欧洲| 永久免费毛片在线观看| 宅男在线国产精品| 久草在线新免费首页资源站| 国产在线欧美日韩| 久久亚洲色图| 久久国产美女视频| 亚洲激情第一页| 日韩中文视频| 国产精品igao激情视频| 97久久超碰精品国产| 中文字幕精品一区二| 米奇精品一区二区三区在线观看| 国产精品毛片视频| 亚欧在线免费观看| 亚洲老妇xxxxxx| 四虎影院在线域名免费观看| 国产精品久久久久久久久久久新郎 | 日韩午夜在线| 微拍福利一区二区| 日韩午夜在线播放| 美女18一级毛片一品久道久久综合| 日韩精品欧美在线| 国产精品一二三在| 老熟妇仑乱一区二区av| 成人三级av在线| 亚洲欧洲一区二区福利| 高清久久久久久| 国产99免费视频| 欧美激情精品久久久久久大尺度| 国产精品亚洲片在线播放| 国产男女无遮挡猛进猛出| 色综合久久天天综合网|