日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Flink从入门到放弃之源码解析系列-第1章 Flink组件和逻辑计划

發布時間:2024/4/14 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Flink从入门到放弃之源码解析系列-第1章 Flink组件和逻辑计划 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

>請戳GitHub原文: github.com/wangzhiwubi…


本文參考了網上很多博客,大多數博客都是基于1.1.0版本的,已經嚴重滯后,本系列文章做了很多訂正,歡迎大家指正。

概要和背景

flink是一個被譽為 the 4th G 的計算框架,不同的框架特性及其代表項目列表如下:

第一代

第二代

第三代

第四代

Batch

BatchInteractive

Batch Interactive Near-Real-TimeInterative-processing

Hybrid Interactive Real-Time-StreamingNative-Iterative-processing


DAG Dataflows

RDD

Cyclic Dataflows

Hadoop MapReduce

TEZ

Spark

Flink

本文主要介紹flink的核心組件以及物理計劃的生成過程

參考代碼分支 flink-1.7.1 本系列大概有7-10章,那3章是留給阿里開源的Blink的新特性的。。。

核心組件介紹

這里只介紹 on yarn 模式下的組件flink 的 on yarn 模式支持兩種不同的類型:
  • 單作業單集群
  • 多作業單集群
  • 首先介紹 單作業單集群 的架構,單作業單集群下一個正常的 flink 程序會擁有以下組件job Cli: 非 detatched 模式下的客戶端進程,用以獲取 yarn Application Master 的運行狀態并將日志輸出掉終端JobManager[JM]: 負責作業的運行時計劃 ExecutionGraph 的生成、物理計劃生成和作業調度TaskManager[TM]: 負責被分發 task 的執行、心跳/狀態上報、資源管理Tips: 啟動Flink Yarn Session有2種模式:分離模式、客戶端模式 通過-d指定分離模式,即客戶端在啟動Flink Yarn Session后,就不再屬于Yarn Cluster的一部分。如果想要停止Flink Yarn Application,需要通過yarn application -kill 命令來停止。 整體的架構大致如下圖所示:

    下面將以一次 Job 的提交過程描述 flink 的各組件的作用及協同

    作業提交流程分析

    單作業單集群模式下,一個作業會啟動一個 JM,并依據用戶的參數傳遞啟動相應數量的 TM,每個 TM 運行在 yarn 的一個 container 中,一個通常的 flink on yarn 提交命令:./bin/flink run -m yarn-cluster -yn 2 -j flink-demo-1.0.0-with-dependencies.jar —ytm 1024 -yst 4 -yjm 1024 —yarnname flink_demo flink 在收到這樣一條命令后會首先通過 Cli 獲取 flink 的配置,并解析命令行參數。

    配置加載

    CliFrontend.java 是 flink 提交作業的入口//CliFrontend line144// 1. find the configuration directoryfinal String configurationDirectory = getConfigurationDirectoryFromEnv();
    這里會嘗試加載 conf 文件夾下的所有 yaml 文件,配置文件的命名并沒有強制限制

    參數解析

    解析命令行參數的第一步是路由用戶的命令,然后交由run方法去處理//CliFrontend line1119try { final CliFrontend cli = new CliFrontend( configuration,customCommandLines);
    SecurityUtils.install(new SecurityConfiguration(cli.configuration)); int retCode = SecurityUtils.getInstalledContext() .runSecured(() -> cli.parseParameters(args)); System.exit(retCode);}catch (Throwable t) { final Throwable strippedThrowable = ExceptionUtils.stripException(t, UndeclaredThrowableException.class); LOG.error("Fatal error while running command line interface.", strippedThrowable); strippedThrowable.printStackTrace();System.exit(31);}
    //CliFrontend line1046try { // do action switch (action) { case ACTION_RUN: run(params);return 0; case ACTION_LIST: list(params);return 0; case ACTION_INFO: info(params);return 0; case ACTION_CANCEL: cancel(params);return 0; case ACTION_STOP: stop(params);return 0; case ACTION_SAVEPOINT: savepoint(params);return 0; case ACTION_MODIFY: modify(params);return 0; case "-h": case "--help": CliFrontendParser.printHelp(customCommandLines);return 0; case "-v": case "--version": String version = EnvironmentInformation.getVersion();String commitID = EnvironmentInformation.getRevisionInformation().commitId;System.out.print("Version: " + version); System.out.println(commitID.equals(EnvironmentInformation.UNKNOWN) ? "" : ", Commit ID: " + commitID); return 0; default: System.out.printf("\"%s\" is not a valid action.\n", action); System.out.println();System.out.println("Valid actions are \"run\", \"list\", \"info\", \"savepoint\", \"stop\", or \"cancel\"."); System.out.println();System.out.println("Specify the version option (-v or --version) to print Flink version.");System.out.println();System.out.println("Specify the help option (-h or --help) to get help on the command.");return 1; }} catch (CliArgsException ce) { return handleArgException(ce); } catch (ProgramParametrizationException ppe) { return handleParametrizationException(ppe); } catch (ProgramMissingJobException pmje) { return handleMissingJobException(); } catch (Exception e) { return handleError(e); }}接下來是程序參數設置過程,flink 將 jar包路徑和參數配置封裝成了 PackagedProgram

    //CliFrontend line201final PackagedProgram program;

    flink集群的構建

    集群類型的解析
    獲取參數后下一步就是集群的構建和部署,flink 通過 兩個不同的 CustomCommandLine 來實現不同集群模式的解析,分別是 FlinkYarnSessionCli和 DefaultCLI 解析命令行參數//CliFrontend line1187final String flinkYarnSessionCLI = "org.apache.flink.yarn.cli.FlinkYarnSessionCli"; try { customCommandLines.add(loadCustomCommandLine(flinkYarnSessionCLI, configuration,configurationDirectory,"y", "yarn")); } catch (NoClassDefFoundError | Exception e) { LOG.warn("Could not load CLI class {}.", flinkYarnSessionCLI, e); }
    customCommandLines.add(new DefaultCLI(configuration));
    return customCommandLines; ...//line210 這里將決定Cli的類型final CustomCommandLine<?> customCommandLine = getActiveCustomCommandLine(commandLine); 那么什么時候解析成 Yarn Cluster 什么時候解析成 Standalone 呢?由于FlinkYarnSessionCli被優先添加到customCommandLine,所以會先觸發下面這段邏輯//FlinkYarnSessionCli line422@Overridepublic boolean isActive(CommandLine commandLine) { String jobManagerOption = commandLine.getOptionValue(addressOption.getOpt(), null); boolean yarnJobManager = ID.equals(jobManagerOption); boolean yarnAppId = commandLine.hasOption(applicationId.getOpt()); return yarnJobManager || yarnAppId || (isYarnPropertiesFileMode(commandLine) && yarnApplicationIdFromYarnProperties != null); }從上面可以看出如果用戶傳入了 -m參數或者application id或者配置了yarn properties 文件,則啟動yarn cluster模式,否則是Standalone模式的集群
    集群部署
    flink通過YarnClusterDescriptor來描述yarn集群的部署配置,具體對應的配置文件為flink-conf.yaml,通過下面這段邏輯觸發集群部署://YarnClusterDescriptor line39public class YarnClusterDescriptor extends AbstractYarnClusterDescriptor {
    public YarnClusterDescriptor( Configuration flinkConfiguration,YarnConfiguration yarnConfiguration,String configurationDirectory,YarnClient yarnClient,boolean sharedYarnClient) { super( flinkConfiguration,yarnConfiguration,configurationDirectory,yarnClient,sharedYarnClient);}//AbstractYarnClusterDescriptor 471protected ClusterClient<ApplicationId> deployInternal( ClusterSpecification clusterSpecification,String applicationName,String yarnClusterEntrypoint,@Nullable JobGraph jobGraph, boolean detached) throws Exception { 大致過程:
    • check yarn 集群隊列資源是否滿足請求
    • 設置 AM Context、啟動命令、submission context
    • 通過 yarn client submit am context
    • 將yarn client 及相關配置封裝成 YarnClusterClient 返回
    真正在 AM 中運行的主類是 YarnApplicationMasterRunner,它的 run方法做了如下工作:
    • 啟動JobManager ActorSystem
    • 啟動 flink ui
    • 啟動YarnFlinkResourceManager來負責與yarn的ResourceManager交互,管理yarn資源
    • 啟動 actor System supervise 進程
    到這里 JobManager 已經啟動起來這樣一個 flink 集群便構建出來了。下面附圖解釋下這個流程:
  • flink cli 解析本地環境配置,啟動 ApplicationMaster
  • 在 ApplicationMaster 中啟動 JobManager
  • 在 ApplicationMaster 中啟動YarnFlinkResourceManager
  • YarnFlinkResourceManager給JobManager發送注冊信息
  • YarnFlinkResourceManager注冊成功后,JobManager給YarnFlinkResourceManager發送注冊成功信息
  • YarnFlinkResourceManage知道自己注冊成功后像ResourceManager申請和TaskManager數量對等的 container
  • 在container中啟動TaskManager
  • TaskManager將自己注冊到JobManager中


  • 接下來便是程序的提交和運行程序在CliFrontend中被提交后,會觸發這樣一段邏輯//ClusterClient 39public JobSubmissionResult run(PackagedProgram prog, int parallelism) throws ProgramInvocationException, ProgramMissingJobException { Thread.currentThread().setContextClassLoader(prog.getUserCodeClassLoader());if (prog.isUsingProgramEntryPoint()) {
    final JobWithJars jobWithJars; if (hasUserJarsInClassPath(prog.getAllLibraries())) { jobWithJars = prog.getPlanWithoutJars();} else { jobWithJars = prog.getPlanWithJars();}
    return run(jobWithJars, parallelism, prog.getSavepointSettings()); }else if (prog.isUsingInteractiveMode()) { log.info("Starting program in interactive mode (detached: {})", isDetached());
    final List<URL> libraries; if (hasUserJarsInClassPath(prog.getAllLibraries())) { libraries = Collections.emptyList();} else { libraries = prog.getAllLibraries();}
    ContextEnvironmentFactory factory = new ContextEnvironmentFactory(this, libraries, prog.getClasspaths(), prog.getUserCodeClassLoader(), parallelism, isDetached(),prog.getSavepointSettings());ContextEnvironment.setAsContext(factory);
    try { // invoke main method prog.invokeInteractiveModeForExecution(); if (lastJobExecutionResult == null && factory.getLastEnvCreated() == null) { throw new ProgramMissingJobException("The program didn't contain a Flink job."); }if (isDetached()) { // in detached mode, we execute the whole user code to extract the Flink job, afterwards we run it here return ((DetachedEnvironment) factory.getLastEnvCreated()).finalizeExecute(); }else { // in blocking mode, we execute all Flink jobs contained in the user code and then return here return this.lastJobExecutionResult; }}finally { ContextEnvironment.unsetContext();}}else { throw new ProgramInvocationException("PackagedProgram does not have a valid invocation mode."); }}注意到有一段prog.invokeInteractiveModeForExecution(),這是客戶端生成初步邏輯計劃的核心邏輯,下面將詳細介紹

    客戶端邏輯計劃

    上面提到prog.invokeInteractiveModeForExecution()這段邏輯會觸發客戶端邏輯計劃的生成,那么是怎樣一個過程呢?其實這里只是調用了用戶jar包的主函數,真正的觸發生成過程由用戶代碼的執行來完成。例如用戶寫了這樣一段 flink 代碼:object FlinkDemo extends App with Logging{ override def main(args: Array[String]): Unit ={ val properties = new Properties properties.setProperty("bootstrap.servers", DemoConfig.kafkaBrokerList)
    properties.setProperty("zookeeper.connect","host01:2181,host02:2181,host03:2181/kafka08")properties.setProperty("group.id", "flink-demo")
    val env = StreamExecutionEnvironment.getExecutionEnvironment env.enableCheckpointing(5000L, CheckpointingMode.EXACTLY_ONCE) //checkpoint every 5 seconds. val stream = env.addSource(new FlinkKafkaConsumer08[String]("log.waimai_e", new SimpleStringSchema, properties)).setParallelism(2) val counts = stream.name("log.waimai_e").map(toPoiIdTuple(_)).filter(_._2 != null) .keyBy(0).timeWindow(Time.seconds(5)).sum(1)
    counts.addSink(sendToKafka(_))env.execute()}注意到這樣一段val env = StreamExecutionEnvironment.getExecutionEnvironment,這段代碼會獲取客戶端的環境配置,它首先會轉到這樣一段邏輯://StreamExecutionEnvironment 1256public static StreamExecutionEnvironment getExecutionEnvironment() { if (contextEnvironmentFactory != null) { return contextEnvironmentFactory.createExecutionEnvironment(); }
    // because the streaming project depends on "flink-clients" (and not the other way around) // we currently need to intercept the data set environment and create a dependent stream env. // this should be fixed once we rework the project dependencies ExecutionEnvironment env = ExecutionEnvironment.getExecutionEnvironment(); ExecutionEnvironment.getExecutionEnvironment();獲取環境的邏輯如下://ExecutionEnvironment line1137public static ExecutionEnvironment getExecutionEnvironment() { return contextEnvironmentFactory == null ? createLocalEnvironment() : contextEnvironmentFactory.createExecutionEnvironment(); }這里的contextEnvironmentFactory是一個靜態成員,早在ContextEnvironment.setAsContext(factory)已經觸發過初始化了,其中包含了如下的環境信息://ContextEnvironmentFactory line51public ContextEnvironmentFactory(ClusterClient client, List<URL> jarFilesToAttach, List<URL> classpathsToAttach, ClassLoader userCodeClassLoader, int defaultParallelism, boolean isDetached, String savepointPath) {this.client = client; this.jarFilesToAttach = jarFilesToAttach; this.classpathsToAttach = classpathsToAttach; this.userCodeClassLoader = userCodeClassLoader; this.defaultParallelism = defaultParallelism; this.isDetached = isDetached; this.savepointPath = savepointPath; }其中的 client 就是上面生成的 YarnClusterClient,其它的意思較明顯,就不多做解釋了。用戶在執行val env = StreamExecutionEnvironment.getExecutionEnvironment這樣一段邏輯后會得到一個StreamContextEnvironment,其中封裝了 streaming 的一些執行配置 【buffer time out等】,另外保存了上面提到的 ContextEnvironment 的引用。到這里關于 streaming 需要的執行環境信息已經設置完成。

    初步邏輯計劃 StreamGraph 的生成

    接下來用戶代碼執行到DataStream<String> stream = env.addSource(consumer);這段邏輯實際會生成一個DataStream抽象,DataStream是flink關于streaming抽象的最核心抽象,后續所有的算子轉換都會在DataStream上來完成,上面的addSource操作會觸發下面這段邏輯:public <OUT> DataStreamSource<OUT> addSource(SourceFunction<OUT> function, String sourceName, TypeInformation<OUT> typeInfo) {
    if (typeInfo == null) { if (function instanceof ResultTypeQueryable) { typeInfo = ((ResultTypeQueryable<OUT>) function).getProducedType(); } else { try { typeInfo = TypeExtractor.createTypeInfo( SourceFunction.class, function.getClass(), 0, null, null); } catch (final InvalidTypesException e) { typeInfo = (TypeInformation<OUT>) new MissingTypeInfo(sourceName, e); } } }
    boolean isParallel = function instanceof ParallelSourceFunction;
    clean(function); StreamSource<OUT, ?> sourceOperator; if (function instanceof StoppableFunction) { sourceOperator = new StoppableStreamSource<>(cast2StoppableSourceFunction(function)); } else { sourceOperator = new StreamSource<>(function); }
    return new DataStreamSource<>(this, typeInfo, sourceOperator, isParallel, sourceName); } 簡要總結下上面的邏輯:
    • 獲取數據源 source 的 output 信息 TypeInformation
    • 生成 StreamSource sourceOperator
    • 生成 DataStreamSource【封裝了 sourceOperator】,并返回
    • 將 StreamTransformation 添加到算子列表 transformations 中【只有 轉換 transform 操作才會添加算子,其它都只是暫時做了 transformation 的疊加封裝】
    • 后續會在 DataStream 上做操作
    DataStreamSource 是一個 DataStream 數據流抽象,StreamSource 是一個 StreamOperator 算子抽象,在 flink 中一個 DataStream 封裝了一次數據流轉換,一個 StreamOperator 封裝了一個函數接口,比如 map、reduce、keyBy等。關于算子的介紹會另起一節:flink算子的生命周期可以看到在 DataStream 上可以進行一系列的操作(map filter 等),來看一個常規操作比如 map 會發生什么://DataStream 583public <R> SingleOutputStreamOperator<R> map(MapFunction<T, R> mapper) {
    TypeInformation<R> outType = TypeExtractor.getMapReturnTypes(clean(mapper), getType(), Utils.getCallLocationName(), true);
    return transform("Map", outType, new StreamMap<>(clean(mapper))); }一個map操作會觸發一次 transform,那么transform做了什么工作呢?//DataStream line1175@PublicEvolvingpublic <R> SingleOutputStreamOperator<R> transform(String operatorName, TypeInformation<R> outTypeInfo, OneInputStreamOperator<T, R> operator) {
    // read the output type of the input Transform to coax out errors about MissingTypeInfo transformation.getOutputType();
    OneInputTransformation<T, R> resultTransform = new OneInputTransformation<>( this.transformation, operatorName,operator,outTypeInfo,environment.getParallelism());
    @SuppressWarnings({ "unchecked", "rawtypes" }) SingleOutputStreamOperator<R> returnStream = new SingleOutputStreamOperator(environment, resultTransform);
    getExecutionEnvironment().addOperator(resultTransform);
    return returnStream; }這一步生成了一個 StreamTransformation并以此作為成員變量封裝成另一個 DataStream 返回,StreamTransformation是 flink關于數據流轉換的核心抽象,只有需要 transform 的流才會生成新的DataStream 算子,后面會詳細解釋,注意上面有這一行getExecutionEnvironment().addOperator(resultTransform)flink會將transformation維護起來://StreamExecutionEnvironment line 1576@Internalpublic void addOperator(StreamTransformation<?> transformation) { Preconditions.checkNotNull(transformation, "transformation must not be null."); this.transformations.add(transformation); }所以,用戶的一連串操作 map join等實際上在 DataStream 上做了轉換,并且flink將這些 StreamTransformation 維護起來,一直到最后,用戶執行 env.execute()這樣一段邏輯,StreamGraph 的構建才算真正開始...用戶在執行 env.execute()會觸發這樣一段邏輯://StreamContextEnvironment line32public JobExecutionResult execute(String jobName) throws Exception { Preconditions.checkNotNull("Streaming Job name should not be null.");
    StreamGraph streamGraph = this.getStreamGraph(); streamGraph.setJobName(jobName);
    transformations.clear();
    // execute the programs if (ctx instanceof DetachedEnvironment) { LOG.warn("Job was executed in detached mode, the results will be available on completion."); ((DetachedEnvironment) ctx).setDetachedPlan(streamGraph);return DetachedEnvironment.DetachedJobExecutionResult.INSTANCE; } else { return ctx.getClient().runBlocking(streamGraph, ctx.getJars(), ctx.getClasspaths(), ctx.getUserCodeClassLoader(), ctx.getSavepointPath()); }}}這段代碼做了兩件事情:
    • 首先使用 StreamGraphGenerator 產生 StreamGraph
    • 使用 Client 運行 stream graph
    那么 StreamGraphGenerator 做了哪些操作呢?StreamGraphGenerator會依據添加算子時保存的 transformations 信息生成 job graph 中的節點,并創建節點連接,分流操作 如 union,select,split 不會添加邊,只會創建虛擬節點或在上有節點添加 selector這里會將 StreamTransformation 轉換為 StreamNode,StreamNode 保存了算子的信息,如下圖所示到這里由 StreamNode 構成的 DAG 圖 StreamGraph就生成了不過 在提交給 client 的時候,flink 會做進一步的優化:StreamGraph 將進一步轉換為 JobGraph,這一步工作由 StreamingJobGraphGenerator 來完成,為什么要做這一步轉換呢?主要因為有可以 chain 的算子,這里進一步將 StreamNode 轉換為 JobVertex,主要工作是將可以 chain 的算子合并【這一步優化是默認打開的】,并設置資源,重試策略等,最終生成可以提交給 JobManager 的 JobGraphTips: JobVertex:經過優化后符合條件的多個StreamNode可能會chain在一起生成一個JobVertex,即一個JobVertex包含一個或多個operator,JobVertex的輸入是JobEdge,輸出是IntermediateDataSet。 IntermediateDataSet:表示JobVertex的輸出,即經過operator處理產生的數據集。producer是JobVertex,consumer是JobEdge。 JobEdge:代表了job graph中的一條數據傳輸通道。source 是 IntermediateDataSet,target 是 JobVertex。即數據通過JobEdge由IntermediateDataSet傳遞給目標JobVertex。


    總結

    以上是生活随笔為你收集整理的Flink从入门到放弃之源码解析系列-第1章 Flink组件和逻辑计划的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    五月婷婷狠狠 | 免费在线观看一级片 | 久久免费av电影 | 日本在线视频一区二区三区 | 国产成人三级在线播放 | 久久久久欠精品国产毛片国产毛生 | 久久一区二区三区日韩 | 欧美日韩亚洲第一 | 国产永久免费观看 | 国产精品1区2区 | 久草视频免费播放 | 狠狠久久婷婷 | 激情亚洲综合在线 | 国产69久久久欧美一级 | 国产成人精品一区二区三区网站观看 | 在线免费观看麻豆视频 | 久久在线影院 | av 一区二区三区四区 | 992tv又爽又黄的免费视频 | 在线观看黄 | 国内精品视频在线 | 久久99久| 欧美日韩精品影院 | 一级片免费在线 | 国产精品99久久99久久久二8 | 99久久日韩精品视频免费在线观看 | 激情久久网 | 九九在线高清精品视频 | 玖玖视频免费在线 | se视频网址 | 国产一区二区不卡视频 | 亚洲人在线7777777精品 | 九九免费在线观看视频 | 亚洲精品乱码久久久久久蜜桃欧美 | 亚洲最大av在线播放 | 久久久久久久久久久久久影院 | 美女视频一区二区 | 日本中出在线观看 | 九九视频免费观看视频精品 | 色橹橹欧美在线观看视频高清 | 91九色精品国产 | 免费91在线观看 | 91资源在线 | 久久久久久久久久久免费av | 韩国一区二区在线观看 | 日韩中文字幕在线看 | 成人欧美在线 | 91精品国产麻豆 | 在线观看黄色 | 91高清视频免费 | 日韩av不卡在线 | 日韩精品久久久 | 午夜美女福利 | 国产一级性生活视频 | 九色视频网 | 久草久草在线观看 | 国产精品一区二区久久久 | 最新国产中文字幕 | 伊人影院在线观看 | 五月色婷| 国产色久 | 亚洲精品午夜国产va久久成人 | 日韩欧美v | 又污又黄的网站 | 久久在线视频精品 | 国产视频在线观看免费 | 国产黄免费在线观看 | 亚洲成人av电影在线 | 99精品视频精品精品视频 | 久草网站在线观看 | 免费亚洲一区二区 | 最近久乱中文字幕 | 日本黄区免费视频观看 | 国产视频精选在线 | 久久免费资源 | 国际精品久久久久 | 在线电影中文字幕 | 又色又爽又黄 | av不卡中文字幕 | 久久精品视频在线免费观看 | 久久撸在线视频 | 国产精品成 | 天天色综合久久 | 免费观看91视频大全 | 伊人色**天天综合婷婷 | 五月天网站在线 | 手机av在线免费观看 | 久久国产精品99久久久久 | 欧美福利精品 | 久久一精品 | 国产视频一区在线 | 日韩欧美精品免费 | 成x99人av在线www | 日本韩国精品一区二区在线观看 | 成人免费视频网 | 97在线精品视频 | 91精品在线免费观看 | 国产成人精品女人久久久 | 欧美日韩在线视频一区 | 久草免费福利在线观看 | 久久久久成 | 五月天天天操 | 国产成人一区二区三区免费看 | 成人综合婷婷国产精品久久免费 | 欧美日韩在线观看一区二区 | 在线一区电影 | 国产精品美女久久久免费 | 九九热免费视频在线观看 | 中文字幕在线观看av | 国产精品久久久久久久午夜片 | 久久高清免费观看 | 亚洲va欧美va人人爽春色影视 | 激情综合网婷婷 | 在线成人高清电影 | 综合久久网站 | 日韩精品第1页 | 精品久久国产精品 | 国产精品毛片一区二区三区 | 国产xxxx | 成人网在线免费视频 | 国产精品高潮在线观看 | 国产免费国产 | 日操操| 日韩视频一区二区三区在线播放免费观看 | 精品国产片 | 欧美日韩一区二区在线观看 | 成人黄色av免费在线观看 | 一级黄色片毛片 | 狠狠色狠狠色综合系列 | 99久久日韩精品免费热麻豆美女 | 欧美日产在线观看 | av高清一区二区三区 | 99在线视频观看 | 欧美午夜精品久久久久 | 欧美成人一二区 | 成人久久18免费网站 | 国产精品av免费在线观看 | 一区二区三区在线播放 | 国内精品小视频 | 97成人在线观看视频 | 日韩高清免费电影 | 欧美一区在线看 | 涩涩爱夜夜爱 | av片在线看 | 久久国产一区二区 | 久久黄色免费观看 | 国产系列在线观看 | 五月开心六月伊人色婷婷 | 天天操夜夜爱 | 曰本三级在线 | 99国产精品久久久久久久久久 | 日韩精品一区二区三区视频播放 | 911av视频 | 亚洲精品456在线播放 | 精品自拍sae8—视频 | 人人草在线视频 | 国产一级片网站 | 麻豆成人精品视频 | 久久国产精品偷 | 99久久9 | 激情视频久久 | 一级一片免费看 | 免费在线观看亚洲视频 | 久久久www成人免费毛片麻豆 | 久久男人视频 | 在线导航av| 一二区精品 | 久久久久麻豆v国产 | 五月婷婷久 | 免费网站色 | 黄色一级大片免费看 | 久艹视频在线免费观看 | 国产群p视频 | 国产日韩精品一区二区在线观看播放 | 91视频 - v11av | 成人av片免费观看app下载 | 精品视频在线看 | 亚洲日本精品视频 | 日韩精品一二三 | av爱干| 美女天天操 | 免费日韩 精品中文字幕视频在线 | 久久国产片 | 在线观看视频 | 狠狠色丁香久久婷婷综合五月 | 日韩中文字幕亚洲一区二区va在线 | 99午夜| 人人艹人人 | 欧美精品久久99 | 狠狠色噜噜狠狠狠合久 | 国产在线美女 | 日韩精品一区二区三区在线播放 | 亚洲高清激情 | 免费观看成人网 | 国产精品videossex国产高清 | 一区 在线 影院 | 91插插插免费视频 | 天天干天天干天天射 | 欧美精品乱码99久久影院 | 九九久久在线看 | 96av麻豆蜜桃一区二区 | 99精品久久只有精品 | 最近中文字幕免费av | 国产91精品久久久久 | 亚洲欧美精品一区 | 狠狠色丁香久久婷婷综合丁香 | 久久久久黄 | 久久国产精品免费一区二区三区 | 天天在线视频色 | 国产成人61精品免费看片 | 五月花激情 | 中文字幕av最新更新 | 久久国产片 | 91精品视频在线看 | 色婷婷免费 | 日日操天天操狠狠操 | 久草99 | 国产三级精品三级在线观看 | 久久亚洲私人国产精品 | 婷婷色在线视频 | 综合伊人av | www.五月天激情 | 深爱综合网| 狠狠色伊人亚洲综合网站色 | 九九九国产 | 久久婷婷国产 | 黄色一级片视频 | 久久久久久网站 | 天天做天天看 | 亚洲精品福利视频 | 人人超碰人人 | 日韩免费观看视频 | 91精品免费在线视频 | 国产97视频 | 丝袜美女在线观看 | 99久久爱 | 日韩午夜在线播放 | 九色琪琪久久综合网天天 | 欧美日韩在线免费观看视频 | www.天天射.com | 亚洲综合色视频在线观看 | 最近高清中文在线字幕在线观看 | 开心丁香婷婷深爱五月 | 在线观看日韩中文字幕 | 国产亚洲精品久久久久久移动网络 | 最新日韩视频 | 亚洲性少妇性猛交wwww乱大交 | 国产成人av综合色 | 欧美日韩一区二区在线观看 | 欧美a√大片 | 久久午夜羞羞影院 | 一本一本久久a久久精品牛牛影视 | 亚洲经典中文字幕 | 国产在线日本 | 一色屋精品视频在线观看 | 久久综合九色综合欧美就去吻 | 色久网 | 91精品视频免费看 | 综合激情网 | 亚洲一区二区视频在线 | 日本三级吹潮在线 | 99久久久久免费精品国产 | 欧美综合在线视频 | 久久精品牌麻豆国产大山 | 亚洲最大激情中文字幕 | 欧美性高跟鞋xxxxhd | 五月婷婷丁香综合 | 国产精品不卡一区 | 亚洲国产福利视频 | 久久久久久久久久久免费视频 | 国产成人免费精品 | 欧美日韩精品在线观看 | 成年人免费在线 | 国产麻豆视频在线观看 | 亚洲综合成人专区片 | 精品毛片一区二区免费看 | 91干干干 | 精品久操 | 在线观看免费av网 | 中文字幕国产精品一区二区 | 伊人亚洲精品 | 免费在线一区二区 | 色多多视频在线观看 | 亚洲欧美日韩精品久久久 | 欧美久久电影 | 亚洲欧美视频一区二区三区 | 国产在线欧美 | 99视频偷窥在线精品国自产拍 | 国产视频中文字幕在线观看 | 91女神的呻吟细腰翘臀美女 | 精品免费久久久久 | 日韩电影在线观看一区二区三区 | 亚洲视频一区二区三区在线观看 | 久二影院 | 草久在线观看视频 | 天天爽天天碰狠狠添 | 日韩久久久久久久久 | 激情欧美xxxx | 久久久久成 | 久久久久综合精品福利啪啪 | 国产精品18久久久久久首页狼 | 中文字幕av一区二区三区四区 | 免费看一级片 | 日韩精品视频在线免费观看 | 综合在线观看色 | 91av电影在线观看 | 色香com.| 人人看人人做人人澡 | av综合站| 一区二区中文字幕在线观看 | 青青草视频精品 | 99riav1国产精品视频 | 男女拍拍免费视频 | 中文字幕中文字幕在线中文字幕三区 | 91网页版在线观看 | 国产一区二区在线观看视频 | 国产精品网红福利 | 精品久久久久久国产91 | 久久一视频 | 在线小视频你懂的 | 视频在线91 | 草久久精品 | 黄色三级在线观看 | 成人中文字幕+乱码+中文字幕 | 视频一区二区免费 | 中文字幕在线观看亚洲 | 久久成人免费 | 综合久久2023 | 久久久久99精品成人片三人毛片 | 正在播放亚洲精品 | 欧美精品乱码久久久久久按摩 | 成年人免费在线 | 亚洲精品麻豆 | 国产精品久久久久免费 | 99热这里只有精品8 久久综合毛片 | 九九免费精品 | 国产精品24小时在线观看 | 视频二区在线视频 | 久久久国产一区二区 | 人人干网 | 五月天天在线 | 五月天六月婷婷 | 色婷婷一区 | 在线电影91| 亚洲精品美女在线观看 | 久久午夜精品影院一区 | 中文高清av | 精品在线视频一区二区三区 | 天天干,天天操,天天射 | 久久96国产精品久久99软件 | 中文字幕av在线电影 | 999电影免费在线观看2020 | 久久激情视频 久久 | 日韩毛片在线一区二区毛片 | www.久久久.com | 久久a v电影| 天天在线免费视频 | 激情影院在线观看 | 亚洲精品成人 | 国产无遮挡猛进猛出免费软件 | 久久理论片 | 欧美日韩高清一区二区 国产亚洲免费看 | 在线va网站 | 精品国产乱码久久 | 亚洲精品国产欧美在线观看 | 在线观看www. | 在线观看视频 | 亚洲国产精品资源 | 69精品视频在线观看 | 国产黄色片免费观看 | 久久国产精品99久久久久久进口 | 欧美日韩性视频在线 | 91av原创| av电影在线观看完整版一区二区 | 91精品无人成人www | 色婷婷国产精品一区在线观看 | 精品国产免费观看 | 国产在线欧美 | 亚洲精品影视 | 中文字幕一区二区三区久久 | 91成人精品一区在线播放69 | 成人影视免费 | 99久久精品国产一区 | 欧美在一区 | 三级在线国产 | 中文字幕乱码日本亚洲一区二区 | 麻豆av一区二区三区在线观看 | 美女一二三区 | 精品麻豆 | 97精品一区二区三区 | 91女神的呻吟细腰翘臀美女 | 国产免费叼嘿网站免费 | 久久精品99久久久久久 | 日产乱码一二三区别免费 | 深爱开心激情 | 五月综合婷| 久久久久久黄色 | 亚洲久草网 | 日韩一区视频在线 | 免费毛片一区二区三区久久久 | 欧美韩日视频 | 一区二区三区视频在线 | 天天狠狠| 日韩成人av在线 | 视频91在线 | 日本久久久久 | 免费高清在线观看成人 | 色av资源网 | 91福利视频在线 | 国产精品成人免费 | 国产精品综合在线观看 | a√资源在线 | 亚洲 欧美 精品 | 久久婷亚洲五月一区天天躁 | 久久人人爽人人爽 | 久草在线高清 | 一区二区精品在线 | 国产精品一区在线观看你懂的 | 久久香蕉电影 | 亚洲黄色片 | 综合激情婷婷 | 久久人人爽人人人人片 | 91黄色小网站 | 美女在线免费视频 | 亚洲精品www久久久久久 | 色婷婷综合久色 | 国产伦理一区二区三区 | 国产高清视频免费在线观看 | 精品一区二区在线免费观看 | 国产女人免费看a级丨片 | 亚洲国产精品va在线看黑人 | 欧美91精品国产自产 | 婷婷激情在线观看 | 免费在线观看国产精品 | 午夜黄色影院 | 亚洲精品xx| 在线观看日本高清mv视频 | 啪啪凸凸 | 高清国产一区 | 天天视频色版 | 天天插天天狠 | 亚洲成人家庭影院 | 欧美日韩久久一区 | 国产在线免费观看 | 在线 国产 日韩 | 日韩三级不卡 | 日韩va欧美va亚洲va久久 | 91精品久久久久久久久久久久久 | 中文字幕一区二区三区四区视频 | 国精产品永久999 | 国产小视频在线观看免费 | 日本一区二区免费在线观看 | 丁香激情五月 | 中文字幕在线观看免费高清电影 | 99综合影院在线 | 91视频在线免费看 | 色婷婷综合久久久久中文字幕1 | 午夜免费在线观看 | 久久久久久欧美二区电影网 | 国产一区二区在线免费 | 天天色婷婷 | 国产精品夜夜夜一区二区三区尤 | 久久黄色免费视频 | 日韩av在线免费看 | 91成人精品国产刺激国语对白 | 黄色91免费观看 | 五月花丁香婷婷 | 日本精品视频在线播放 | 91九色最新地址 | 91香蕉国产在线观看软件 | 黄色小视频在线观看免费 | 偷拍精偷拍精品欧洲亚洲网站 | 婷婷在线网站 | 91精品免费 | 一区中文字幕电影 | 国产麻豆精品久久 | 免费特级黄毛片 | 中文字幕在线视频一区二区 | 免费av试看 | 久久精品欧美一区二区三区麻豆 | 日韩欧美高清一区二区三区 | 一区二区三区动漫 | 久久久黄视频 | 成人免费观看电影 | 日韩一区二区三区在线看 | 国产99免费视频 | 亚洲三级网站 | 国产aa免费视频 | 久久不卡电影 | 中文在线亚洲 | 91九色在线视频观看 | 成人网看片| 在线观看亚洲a | 夜色资源站国产www在线视频 | 探花视频免费在线观看 | 久久久免费毛片 | 婷婷综合久久 | 国产精品美女久久久久久2018 | 麻豆av一区二区三区在线观看 | 日韩三区在线观看 | 国产色女人 | 精品国产诱惑 | 日韩av免费一区二区 | 五月婷香蕉久色在线看 | 五月婷婷开心中文字幕 | 亚洲精品国产精品国 | 五月天亚洲婷婷 | 日韩欧美一区二区三区在线 | 久久久三级视频 | 婷婷色亚洲 | 日韩sese| 久久蜜臀一区二区三区av | 嫩模bbw搡bbbb搡bbbb | 五月婷婷操 | www黄com | 国产麻豆剧果冻传媒视频播放量 | 日本黄色一级电影 | 久久精品中文字幕一区二区三区 | 欧美日韩国产一二 | 欧美日韩另类视频 | 99国产精品久久久久久久久久 | 国产精品福利av | 国产亚洲精品中文字幕 | 91亚洲永久精品 | 久久精品99视频 | 日韩精品大片 | www.av在线播放 | 国产专区视频在线观看 | 欧美久久影院 | 免费精品久久久 | 99热这里只有精品国产首页 | 国产一级视屏 | 国产韩国日本高清视频 | 日韩精品欧美一区 | 中文字幕一区二区在线播放 | 亚洲一区久久久 | 婷婷激情站 | 欧美 日韩 性 | 夜夜躁狠狠躁日日躁 | 日韩精品91偷拍在线观看 | 午夜精品视频在线 | 日本免费久久高清视频 | 久久8| 国产成人av在线影院 | 久久久久久草 | 免费看成人av | 97国产精品免费 | 五月天六月婷 | 亚洲精品视频在线播放 | 99国产精品久久久久老师 | 99精品国产福利在线观看免费 | av电影在线观看 | av手机在线播放 | 国产老太婆免费交性大片 | 日本中文在线播放 | 337p日本欧洲亚洲大胆裸体艺术 | 久久精品91久久久久久再现 | 99精品免费久久久久久日本 | 99re中文字幕 | 成人免费观看大片 | 精品久久一级片 | 六月丁香在线视频 | 日韩在线视频精品 | 亚洲欧美日本一区二区三区 | 在线免费看片 | 丁香五月亚洲综合在线 | www在线观看国产 | 99视频 | 国产精品九九久久久久久久 | 日韩理论电影在线 | 中文字幕国产一区二区 | 欧美一区二区三区在线播放 | 日韩免费电影 | 少妇bbw揉bbb欧美 | 91在线永久 | 欧美另类高潮 | 成人免费视频a | 成人av动漫在线观看 | 亚洲 欧美日韩 国产 中文 | 99精品视频免费在线观看 | 美女视频黄,久久 | 日韩va欧美va亚洲va久久 | 亚洲欧洲中文日韩久久av乱码 | 国产精品av在线免费观看 | 欧美激精品 | 97色综合| 一级性视频 | 国产成人精品一区二区三区网站观看 | 国产精品久久久久久久午夜 | 国产亚洲精品久久久网站好莱 | 国产精品久久久久久久99 | 亚洲麻豆精品 | 日日操日日插 | 久久精品国产成人 | 久久不卡日韩美女 | 国产资源| 欧美性色综合网 | 97爱| 亚洲伊人成综合网 | 超碰在线最新 | 一区二区三区日韩在线观看 | 超碰大片 | 天堂久久电影网 | 在线国产精品一区 | 欧美aaa视频 | 国产91精品一区二区麻豆亚洲 | www.黄色小说.com | 久久成人精品 | 亚洲v欧美v国产v在线观看 | 精品久久久久久久 | 国产理论免费 | 91免费在线播放 | 欧美91精品久久久久国产性生爱 | 国产在线日韩 | 天天色综合天天 | 免费精品 | 狠狠激情中文字幕 | 国产不卡一二三区 | 精品久久一级片 | 超碰在线免费福利 | 免费午夜网站 | 国产乱码精品一区二区三区介绍 | 国产91学生粉嫩喷水 | 国内精品免费久久影院 | 日韩av在线看 | 色狠狠综合天天综合综合 | 在线观看www. | 精品国产伦一区二区三区观看方式 | 国产区av在线 | 99久久久国产精品免费99 | 999视频网 | 97国产超碰在线 | 久久精品国产久精国产 | 亚洲视频播放 | 亚洲在线综合 | 国产三级av在线 | 韩日电影在线 | 久久经典国产 | 久久免费视频在线观看 | 国产精品99久久99久久久二8 | 久在线| 五月婷久| 九九免费在线观看 | 亚洲成人动漫在线观看 | 亚洲国产精品电影 | 人人爽人人澡人人添人人人人 | 久久午夜影视 | 久 久久影院 | 天天躁日日躁狠狠躁av中文 | 99精品一区二区 | 国产精品一区二区三区四区在线观看 | 国产精品一区二区 91 | 麻豆视频在线看 | 久久久精品国产一区二区三区 | 久草在线中文视频 | 亚洲视频国产 | 18做爰免费视频网站 | 天天干天天操人体 | 国产精品视频不卡 | 久久99网站| 99热这里只有精品久久 | 国产精品99久久久精品免费观看 | 五月婷婷六月丁香在线观看 | 久久免费视频精品 | 久久精品亚洲综合专区 | 欧美国产亚洲精品久久久8v | 在线日韩一区 | 国产麻豆剧传媒免费观看 | 日本特黄一级片 | 人人玩人人爽 | 在线看国产日韩 | www.伊人网.com| 日本性xxxxx 亚洲精品午夜久久久 | 日日摸日日添夜夜爽97 | av在线免费播放网站 | 午夜在线观看一区 | 日韩高清dvd | 欧美精品v国产精品v日韩精品 | 免费看国产视频 | 超碰在线人人艹 | 国产一级性生活 | 日韩亚洲在线视频 | 91精品国产91久久久久 | 久久久久二区 | 亚洲午夜精品久久久 | 亚洲精区二区三区四区麻豆 | 在线v片免费观看视频 | 亚洲第一区在线观看 | 精品久久一区二区 | 国内少妇自拍视频一区 | 国产一区二区三区免费视频 | 久久美女高清视频 | 日本一区二区三区免费看 | 一二区av | 欧美 日韩 国产 成人 在线 | 国产在线v | 久久久www成人免费毛片麻豆 | 在线中文视频 | 视频国产 | 伊人久久婷婷 | 深夜激情影院 | 久久久久久不卡 | 久久久久蜜桃 | 日韩精品一区二区在线视频 | 久久精品9| 久久精品视频在线 | 蜜臀aⅴ国产精品久久久国产 | 97福利在线观看 | 久久久久久久网站 | 国产日韩精品在线观看 | 精品久久精品 | 一区二区三区高清不卡 | 99久久电影 | 国产不卡在线 | 国产午夜免费视频 | 国产男女免费完整视频 | 在线天堂8√ | 绯色av一区 | 91中文字幕在线 | 香蕉视频网站在线观看 | 欧美日韩高清一区二区三区 | 色插综合 | 国产成人精品一二三区 | 91av电影在线 | 激情五月婷婷激情 | 国产精品毛片久久久久久久 | 在线成人中文字幕 | 亚洲 欧美 日韩 综合 | 亚洲综合视频在线观看 | 日韩亚洲欧美中文字幕 | 久久国产成人午夜av影院宅 | 九九热视频在线免费观看 | 国产精品一区二区免费视频 | 国产麻豆精品95视频 | 444av| 日韩久久电影 | 亚洲精品成人av在线 | 有码视频在线观看 | 美女黄频在线观看 | 91试看| 综合精品久久久 | 狠狠操夜夜 | 夜夜躁日日躁 | 99久久精品免费看国产四区 | 日韩一区二区在线免费观看 | 日韩在线电影观看 | 成年人视频在线免费 | 欧美aⅴ在线观看 | 亚洲无人区小视频 | 亚洲精品无 | 国产综合精品一区二区三区 | 特级西西444www大胆高清无视频 | 中文字幕在线观看你懂的 | 欧美九九九 | 免费日韩视频 | 国产色在线观看 | 日韩欧美一区二区三区在线 | 久热这里有精品 | 日日操天天爽 | 天天色天天射综合网 | 1024在线看片 | 中文字幕精 | 国产手机视频在线播放 | 超碰在线免费福利 | 国产剧情在线一区 | 九九久久影院 | 久久99热这里只有精品国产 | 久久久久人人 | 操天天操 | 国产一及片 | 久久久999精品视频 国产美女免费观看 | 91丨九色丨蝌蚪丨对白 | 天天超碰 | 91超在线 | 97超碰精品 | 久草资源免费 | 久久久香蕉视频 | 亚洲精品国产精品久久99 | 国产午夜精品一区二区三区欧美 | 国产精品日韩在线观看 | 久久免费看a级毛毛片 | 欧美俄罗斯性视频 | 午夜少妇av| 国产在线观看一 | 国产中文字幕一区二区 | 麻豆一区在线观看 | 日本精品视频在线播放 | 在线观看国产高清视频 | 久久国产一二区 | 亚洲成人xxx | 日韩中文幕 | 亚洲人视频在线 | 9999激情| 亚洲精品久久视频 | 亚洲精品国产精品国自产观看 | 欧美日韩国产亚洲乱码字幕 | 精品国模一区二区 | 国产亚洲无 | 亚洲综合色站 | 天天艹天天爽 | 天天色天 | 国产免费叼嘿网站免费 | 日本精品午夜 | 久久久久久久综合色一本 | 日韩精品亚洲专区在线观看 | 亚洲精品国产电影 | 色欧美88888久久久久久影院 | 91激情 | 国产精品黄网站在线观看 | 日本久久久影视 | 日韩毛片精品 | 99久久久久免费精品国产 | 亚洲欧洲精品视频 | 黄色小说18 | 国产黑丝袜在线 | www色网站 | 日韩激情中文字幕 | 奇米影视在线99精品 | av在线直接看 | 99在线精品观看 | 日本精品一区二区 | 久久tv | 怡红院av| 欧美先锋影音 | www.亚洲视频.com | 激情av在线播放 | 99精品视频播放 | 国产高清在线免费观看 | 91视频 - x99av | 日韩综合精品 | 波多野结衣亚洲一区二区 | 香蕉视频网站在线观看 | 97精品国自产拍在线观看 | 国产精品中文字幕在线观看 | 又爽又黄又刺激的视频 | 香蕉影院在线 | av一区在线 | 欧美人zozo | 最新国产中文字幕 | 日日夜夜免费精品视频 | 久久一二三四 | 国产精品观看在线亚洲人成网 | 精品国产伦一区二区三区 | 少妇av片 | 国产一区视频导航 | 91精品在线免费观看视频 | 91精品久久久久久久91蜜桃 | 国产91在线免费视频 | 在线观看激情av | 成人禁用看黄a在线 | 精品国产综合区久久久久久 | av千婊在线免费观看 | 国产精品女人久久久久久 | 99视频| 亚洲最新av | 99精品免费久久久久久久久日本 | 亚洲欧美日韩精品久久久 | 日韩av电影国产 | 中文字幕亚洲精品在线观看 | 日本中出在线观看 | 国产美女免费视频 | 亚洲免费精品一区二区 | 99久热在线精品 | 精品久久免费看 | 国产一级片免费视频 | 国产一区不卡在线 | 国产亚洲精品免费 | 国产精品第一页在线 | 天天操天天操天天操天天操 | 三级黄色理论片 | 免费在线观看成人 | 色久天| 黄色一级大片在线观看 | 国产精品丝袜在线 | 97精品国产| 国产精品久久久久久一区二区三区 | 黄色一级片视频 | 久久大视频 | 麻豆传媒电影在线观看 | av久久在线 | 丁香花在线视频观看免费 | 99热在线国产 | 在线播放精品一区二区三区 | 天天综合在线观看 | 国产网红在线观看 | 成人sm另类专区 | 亚洲综合在线五月天 | www操操操| 免费日韩 精品中文字幕视频在线 | 亚洲国产免费 | 久久久午夜剧场 | 日韩中文在线电影 | 午夜精品久久久久久久99热影院 | 欧美一级免费片 | 99se视频在线观看 | 国内成人av | 又黄又爽又色无遮挡免费 | 国内精品久久久久久久影视麻豆 | 狠狠色噜噜狠狠狠狠 | 久久一区二| 免费看久久 | 久久久免费高清视频 | 国产精品一区二区三区四 | 亚洲综合视频在线播放 | 麻豆av一区二区三区在线观看 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 国产精品毛片一区二区 | 美女在线国产 | 欧洲性视频 | 午夜精品久久久久久久久久久 | 狠狠的操狠狠的干 | 国产一级做a爱片久久毛片a | 国内精品久久久久久久久久久 | 日韩一区二区三区高清在线观看 | 在线观看中文字幕一区二区 | 狠狠88综合久久久久综合网 | 日韩网站在线看片你懂的 | 国产精品丝袜久久久久久久不卡 | 伊人久久国产精品 | 欧美a影视 | www.福利视频 | 色中文字幕在线观看 | 五月花婷婷 | 婷婷综合视频 | a久久久久 | 涩涩网站在线播放 | 欧美日韩精品免费观看 | 国产韩国日本高清视频 | 久久97精品 | 91精品国产99久久久久久红楼 | 狠狠躁夜夜躁人人爽超碰97香蕉 | www.久久99| 久久极品 | 国产日韩精品一区二区 | www亚洲一区 | 草免费视频 | 99久久婷婷国产 | 日日摸日日 | 亚洲激情网站免费观看 | 亚洲精品日韩av | 国产99一区视频免费 | 日韩另类在线 | 国产精品18久久久久久久 | 天天摸夜夜操 | 国产91成人在在线播放 | 国产一区二区在线观看视频 | 99免费观看视频 | 国产精品久久久久9999 | 激情自拍av| 最近中文字幕视频完整版 | 亚洲国产中文字幕 | 爱爱一区| 亚洲在线免费视频 | 大胆欧美gogo免费视频一二区 | 国产视频亚洲 | 91在线视频精品 | 中文字幕在线视频精品 | 久久婷婷综合激情 | 日日干综合 | 亚洲一区网站 | 日韩一区精品 | 国产 字幕 制服 中文 在线 | 在线观看成年人 | 欧美激情视频一区二区三区免费 | 亚洲1区 在线 | 天天玩天天干天天操 | 日韩伦理一区二区三区av在线 | 久久手机在线视频 | 韩日电影在线观看 | 成人国产精品一区二区 | 98涩涩国产露脸精品国产网 | 亚洲国产精品电影 | 亚洲欧美日韩国产一区二区 | 久久精品99国产国产 | 婷婷丁香激情综合 | 国产精品毛片完整版 | 91精品免费在线 | 少妇bbr搡bbb搡bbb | 伊人婷婷综合 | 亚洲精品中文在线 | 久久99这里只有精品 | 99热这里只有精品1 av中文字幕日韩 | 在线观看国产一区二区 | 国产色婷婷在线 | 91久久精品日日躁夜夜躁国产 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | av免费看看| 久久综合桃花 | 国产精品v欧美精品 | 久草视频一区 | 精品在线不卡 | 国产一级黄色片免费看 | 日本三级中文字幕在线观看 | 国产最新在线观看 | 国产 日韩 欧美 自拍 | 日韩欧美视频免费在线观看 | 日韩久久久久久久 | 久久乱码卡一卡2卡三卡四 五月婷婷久 |