精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

成人免费网站在线观看视频| 一级做a爱片性色毛片| aiss精品大尺度系列| 亚洲国产视频a| 欧美精品久久久| 91免费视频播放| 在线亚洲观看| 久久久国产一区二区| 香蕉视频污视频| 91大神在线观看线路一区| 一区二区三区中文在线| 欧美日韩在线观看一区二区三区| 亚洲熟女乱色一区二区三区久久久 | 中文字幕高清视频| 国产一精品一av一免费爽爽| 欧美日韩在线免费| 天天成人综合网| 日韩a在线看| 国产盗摄视频一区二区三区| 国产精品69av| 国产一级一片免费播放| 日韩欧美大片| 国产丝袜视频一区| 自拍偷拍激情视频| 欧美韩国日本| 在线一区二区视频| r级无码视频在线观看| 毛片在线视频| 国产色爱av资源综合区| 国产偷久久久精品专区| 国产视频一二三四区| 日韩不卡手机在线v区| 性欧美在线看片a免费观看| 美国一级片在线观看| 日韩成人动漫在线观看| 日韩精品一区二区三区视频播放 | 国产精品夜夜夜爽张柏芝| 日韩美女一级视频| 成人18视频日本| 91免费看网站| 国产色片在线观看| 美女一区二区三区在线观看| 日本视频久久久| 九九九在线观看| 中文亚洲欧美| 77777少妇光屁股久久一区| 欧美爱爱小视频| 亚洲国产成人精品女人| 久久久www成人免费精品| 亚洲一二三精品| 成人亚洲一区| 一本色道久久88综合亚洲精品ⅰ | 亚洲国产日韩在线一区模特| 麻豆md0077饥渴少妇| 国产激情视频在线| 亚洲免费观看高清完整| 懂色av一区二区三区四区五区| 国产三区四区在线观看| 久久美女艺术照精彩视频福利播放| 国产精品大全| 天天影院图片亚洲| 2017欧美狠狠色| 欧美日韩在线高清| av国产在线观看| 国产精品女主播av| 91香蕉视频网址| 在线午夜影院| 亚洲成人av电影| 国产精品秘入口18禁麻豆免会员| 亚洲日本天堂| 欧美性受xxxx| www.偷拍.com| 精品久久ai电影| 国产丝袜精品视频| 国产亚洲精品精品精品| 91精品啪在线观看国产81旧版| 欧美日韩国产成人在线| 男人天堂中文字幕| 久久三级福利| 成人黄色生活片| 免费看黄色一级视频| 久久久久久免费| 最近看过的日韩成人| 中文字幕伦理免费在线视频 | 麻豆免费看一区二区三区| 国产精品大片wwwwww| 免费黄色片视频| 蜜桃一区二区三区四区| 91精品一区二区| 亚洲国产精彩视频| 99九九99九九九视频精品| 精品国产一区二区三区麻豆免费观看完整版 | 狠狠色综合色区| 国产在线黄色| 中文字幕精品在线不卡| japanese在线播放| 1024在线看片你懂得| 欧美午夜丰满在线18影院| 日日碰狠狠躁久久躁婷婷| 成人在线视频观看| 欧美成人猛片aaaaaaa| 国产亚洲色婷婷久久99精品91| 国产成人三级| 久久福利视频网| 欧美成人国产精品高潮| 最新成人av网站| 国产精品九九九| 国产女人爽到高潮a毛片| 粉嫩13p一区二区三区| 欧美系列一区| 怡红院红怡院欧美aⅴ怡春院| 五月天激情小说综合| 在线观看的毛片| 一区二区三区四区高清视频| 亚洲国产欧美一区二区三区同亚洲 | 亚洲情综合五月天| 好吊日在线视频| 久久精品91| 91视频免费在线| 国产黄色片在线观看| 亚洲伦在线观看| 成人精品视频一区二区| 亚洲成人黄色| 中文字幕久久精品| 国产午夜精品一区二区理论影院| 日韩国产欧美在线播放| 国内精品视频在线播放| 欧美激情免费| 欧美午夜精品久久久久久人妖| 亚洲熟女乱综合一区二区| 精品日韩毛片| 26uuu另类亚洲欧美日本一| 国产乱人乱偷精品视频| 91丨porny丨国产| 毛片在线视频观看| 色综合.com| 亚洲欧美中文日韩在线v日本| 欧美精品入口蜜桃| 久久精品99国产精品日本| 国产一区不卡在线观看| 青青草原av在线| 欧美精品一卡二卡| 国产精品免费无码| 一区二区三区国产在线| 99视频日韩| 黄色网页在线播放| 欧美日韩激情一区二区| 成人国产精品久久久网站| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美性aaa| 国产亚洲成av人片在线观看桃| 日本少妇激情视频| 国产91丝袜在线观看| 一级黄色片播放| 香蕉成人在线| 这里只有精品在线播放| 在线观看日本网站| 久久这里只有精品首页| 777777av| 亚洲婷婷影院| 国产成人精品久久二区二区| 欧美一级在线免费观看| 精品国产福利在线| 精品黑人一区二区三区观看时间| 亚洲国产影院| 精品一区二区三区国产| 无遮挡在线观看| 亚洲欧美日韩精品久久奇米色影视| 国产五月天婷婷| 99在线精品观看| 男女高潮又爽又黄又无遮挡| 日本久久成人网| 热久久美女精品天天吊色| 欧美婷婷久久五月精品三区| 欧美性猛交xxxx免费看| 欧美多人猛交狂配| 日韩高清不卡在线| 亚洲视频电影| 欧美1区2区3| 伦伦影院午夜日韩欧美限制| 国产又粗又猛又爽又黄的| 亚洲免费毛片网站| 亚洲精品激情视频| 亚洲一区二区伦理| 日韩av在线一区二区三区| 国产日本久久| 久久国产精品影片| 性xxxfllreexxx少妇| 日韩欧美精品网站| 亚洲综合网在线观看| 九色综合狠狠综合久久| 青草网在线观看| 窝窝社区一区二区| 国产精品高清网站| а√天堂8资源在线官网| 亚洲成在人线av| 久久久久久亚洲av无码专区| 自拍偷拍亚洲激情| 性农村xxxxx小树林| 麻豆精品视频在线| 欧美无砖专区免费| 欧美理论视频| 国产福利久久精品| 国产91欧美| 欧美激情一区二区三区在线视频观看 | 视频一区在线播放| 国产片侵犯亲女视频播放| 亚洲免费成人av在线| 国产精品一区二区久久久久| av毛片在线| 一区二区三区视频在线| 精品国产亚洲一区二区麻豆| 欧美日韩午夜剧场| 毛片视频免费播放| www.欧美亚洲| 激情在线观看视频| 久久精品官网| 亚洲小视频在线播放| 日韩精品电影| 久久久久久高清| www999久久| 国产精彩精品视频| av在线加勒比| 久久影院在线观看| 国产午夜视频在线观看| 精品欧美久久久| 国产高清在线免费| 欧美综合在线视频| 国产精品999在线观看| 亚洲视频在线一区观看| 国产精品无码一区二区三区| 成人午夜大片免费观看| 欧美精品久久久久久久久25p| 亚洲每日更新| 性做爰过程免费播放| 香蕉视频国产精品| 四虎永久国产精品| 日韩欧美中文字幕电影| 99re视频在线| 99精品美女视频在线观看热舞 | 中文字幕中文字幕在线中心一区| 一道在线中文一区二区三区| 超碰97在线资源| 国产高清日韩| 成人两性免费视频| 日韩毛片一区| 国产精品久久久久7777婷婷| 国产三级电影在线播放| 久久男人的天堂| 青草影视电视剧免费播放在线观看| 色香阁99久久精品久久久| 国自产拍在线网站网址视频| 日韩精品极品视频| 香蕉视频网站在线| 亚洲精品美女在线观看| 免费观看的毛片| 亚洲第一精品电影| 日本精品久久久久久| 精品久久久久久久久久久院品网| 国产麻豆免费视频| 欧美一区二区三区免费| 国产精品欧美激情在线| 欧美在线观看视频一区二区| 91在线视频国产| 5566中文字幕一区二区电影| 中文字幕你懂的| 欧美日韩高清一区二区不卡| 97人妻精品一区二区三区视频 | 国产青青草视频| 884aa四虎影成人精品一区| 97人妻精品一区二区三区视频 | 中文字幕第80页| 蜜桃精品视频在线| 在线观看岛国av| 国内精品第一页| av天堂一区二区| 99久久国产综合精品麻豆| 国产+高潮+白浆+无码| 久久精品亚洲精品国产欧美 | 国产精品网在线观看| 欧美日韩另类综合| 欧美一站二站| 超碰成人在线免费观看| 午夜激情一区| 少妇av一区二区三区无码| 久久福利毛片| 国产一伦一伦一伦| 9人人澡人人爽人人精品| 熟女少妇内射日韩亚洲| 国产精品国产三级国产有无不卡| 日本黄色录像视频| 图片区日韩欧美亚洲| 在线永久看片免费的视频| 538prom精品视频线放| 亚洲不卡免费视频| 亚洲色图50p| 国产传媒在线播放| 97在线视频免费| 亚洲同志男男gay1069网站| 成人久久精品视频| 久久99国产精品久久99大师| 一级成人国产| 毛片一区二区| 国产高清在线不卡| 午夜视频在线观看精品中文| 精品一区二区国产| 秋霞欧美视频| 黄色片网址在线观看| 蜜臀av一区二区在线免费观看| 手机在线观看日韩av| 成人av电影在线播放| www欧美com| 一本久久精品一区二区| 国产高潮流白浆喷水视频| 亚洲欧洲第一视频| 色爱综合区网| 国产欧美一区二区三区久久| 精品国内亚洲2022精品成人| 在线免费观看成人| 天堂va蜜桃一区二区三区 | h片在线观看视频免费| 日韩av黄色在线观看| 青草伊人久久| 性刺激综合网| 国产精品人人爽人人做我的可爱| 国产精品自在自线| av电影一区二区| 久久久久无码精品国产| 欧美视频完全免费看| 天堂在线视频免费| 欧美第一淫aaasss性| 国产精品亲子伦av一区二区三区| 精品在线不卡| 亚洲午夜精品一区二区国产 | 久久久久无码国产精品| 欧美精品免费视频| 番号集在线观看| 热99在线视频| 成人av地址| 激情五月婷婷六月| 国产成人综合网| 日韩三级久久久| 欧美日韩视频在线第一区| 每日更新在线观看av| 91av国产在线| 51精品国产| 亚洲精品蜜桃久久久久久| 国产999精品久久| 欧美日韩精品亚洲精品| 91精品在线观看入口| 男人天堂手机在线| 国产精品久久久久福利| 青青草国产免费一区二区下载| 成年人视频网站免费观看| av日韩在线网站| 国产污视频在线看| 亚洲国产精品va在线| 美女91在线| 国内精品**久久毛片app| 999在线观看精品免费不卡网站| 麻豆短视频在线观看| 亚洲香肠在线观看| 好吊色视频一区二区| 欧美精品激情在线| 伊人精品综合| 国产乱子夫妻xx黑人xyx真爽| 91蝌蚪国产九色| 一级片视频在线观看| 亚洲天堂免费视频| 欧美日韩亚洲国产| 视频一区二区在线观看| 国产一区二区福利视频| 国产女人18水真多毛片18精品| 日韩欧美国产午夜精品| 欧美三级黄网| 官网99热精品| 性色av一区二区怡红| 性猛交ⅹxxx富婆video| 欧美日韩在线亚洲一区蜜芽| 第一视频专区在线| 亚洲影院高清在线| 一本色道精品久久一区二区三区 | 亚洲欧美在线x视频| 日韩精品免费观看视频| 51xx午夜影福利| 91亚洲精华国产精华精华液| 无码人妻丰满熟妇区五十路| 色青青草原桃花久久综合| 欧美专区一区| 成人国产在线看| 久久久久久久久久久黄色| 亚洲综合精品国产一区二区三区| 久久亚洲精品中文字幕冲田杏梨| 成人av激情人伦小说| 国产成人综合一区| 国产精品麻豆一区二区 | 99人久久精品视频最新地址| 最近中文字幕免费| 欧美精品欧美精品系列| 欧美久久天堂|