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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Spark 常用算子详解(转换算子、行动算子、控制算子)

發布時間:2024/3/12 编程问答 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spark 常用算子详解(转换算子、行动算子、控制算子) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Spark簡介

Spark是專為大規模數據處理而設計的快速通用的計算引擎;
Spark擁有Hadoop MapReduce所具有的優點,但是運行速度卻比MapReduce有很大的提升,特別是在數據挖掘、機器學習等需要迭代的領域可提升100x倍的速度:

  • Spark是基于內存進行數據處理的,MapReduce是基于磁盤進行數據處理的;
  • Spark中具有DAG有向無環圖,DAG有向無環圖在此過程中減少了shuffle以及落地磁盤的次數;

  • Spark流程

  • Spark Application的運行環境:創建SparkConf對象
      • 可以設置Application name;
      • 可以設置運行模式及資源需求;
  • 創建SparkContext對象;
      • SparkContext向資源管理器申請運行Executor資源,并啟動StandaloneExecutorbackend;
      • Executor向SparkContext申請Task;
      • SparkContext將程序分發給Executor;
      • SparkContext構建成DAG圖,將DAG圖分解成Stage、將Taskset發送給Task Scheduler,最后由Task Scheduler將Task發送給Executor運行;
      • Task在Excutor上運行,運行完釋放所有的資源;
  • 基于Spark的上下文創建一個RDD,對RDD進行處理;
  • 應用程序中y有Action累算子來觸發Transformation類算子執行;
  • 關閉Spark上下文對象SparkContext;

  • value 類型

    細類型算子
    輸入分區與輸出分區一對一型map flatMap mapPartitions glom
    輸入分區與輸出分區多對一型union cartesain
    輸入分區與輸出分區多對多型groupBy
    輸出分區為輸入分區子集型filter distinct substract sample takeSample
    Cache型cache persist

    key-value類型

    細類型算子
    輸入分區與輸出分區一對一mapValues
    對單個RDD或兩個RDD聚集單個RDD聚集: combineByKey reduceByKey partitionBy; 兩個RDD聚集: Cogroup
    連接join leftOutJoin和 rightOutJoin

    Action算子

    細類型算子
    無輸出foreach
    HDFSsaveAsTextFile saveAsObjectFile
    Scala集合和數據類型collect collectAsMap reduceByKeyLocally lookup count top reduce fold aggregate

    轉換算子(Transformations)

    不觸發提交作業,只是完成作業中間過程處理;Transformation 操作是延遲計算的,也就是說從一個RDD 轉換生成另一個 RDD 的轉換操作不是馬上執行,需要等到有 Action 操作的時候才會真正觸發運算。Transformation參數類型為value或者key-value的形式;

    轉換算子是延遲執行的,也叫懶加載執行

    map

    將原來RDD的每個數據通過map中的用戶自定義函數映射為一個新的元素,源碼中map算子相當于初始化一個RDD --------- f(x)=x -> y

    • scala源碼 def map[U: ClassTag](f: T => U): RDD[U] = withScope {val cleanF = sc.clean(f)new MapPartitionsRDD[U, T](this, (context, pid, iter) => iter.map(cleanF))}

    flatMap

    將原來 RDD 中的每個元素通過函數 f 轉換為新的元素,并將生成的 RDD 的每個集合中的元素合并為一個集合,內部創建 FlatMappedRDD(this,sc.clean(f))。 ------ f: T => TraversableOnce[U]

    • scala源碼

      def flatMap[U: ClassTag](f: T => TraversableOnce[U]): RDD[U] = withScope {val cleanF = sc.clean(f)new MapPartitionsRDD[U, T](this, (context, pid, iter) => iter.flatMap(cleanF))}
    • 例子

      lines.flatMap{lines => {lines.split(" ")

    mapPartitions

    mapPartitions 函 數 獲 取 到 每 個 分 區 的 迭 代器,在 函 數 中 通 過 這 個 分 區 整 體 的 迭 代 器 對整 個 分 區 的 元 素 進 行 操 作。 內 部 實 現 是 生 成 -------f (iter)=>iter.f ilter(_>=3)

    • scala源碼

      def filter(f: T => Boolean): RDD[T] = withScope {val cleanF = sc.clean(f)new MapPartitionsRDD[T, T](this,(context, pid, iter) => iter.filter(cleanF),preservesPartitioning = true)}

    glom

    glom函數將每個分區形成一個數組,內部實現是返回的GlommedRDD。 圖4中的每個方框代表一個RDD分區。圖4中的方框代表一個分區。 該圖表示含有V1、 V2、 V3的分區通過函數glom形成一數組Array[(V1),(V2),(V3)]

    • scala源碼

      def glom(): RDD[Array[T]] = withScope {new MapPartitionsRDD[Array[T], T](this, (context, pid, iter) => Iterator(iter.toArray))}

    union

    使用 union 函數時需要保證兩個 RDD 元素的數據類型相同,返回的 RDD 數據類型和被合并的 RDD 元素數據類型相同,并不進行去重操作,保存所有元素。如果想去重可以使用 distinct()(并集)

    • scala源碼

      def union(other: RDD[T]): RDD[T] = withScope {sc.union(this, other)}

    cartesian

    對 兩 個 RDD 內 的 所 有 元 素 進 行 笛 卡 爾 積 操 作。 操 作 后, 內 部 實 現 返 回CartesianRDD。圖6中左側大方框代表兩個 RDD,大方框內的小方框代表 RDD 的分區。右側大方框代表合并后的 RDD,大方框內的小方框代表分區。圖6中的大方框代表RDD,大方框中的小方框代表RDD分區。

    • scala源碼

      def cartesian[U: ClassTag](other: RDD[U]): RDD[(T, U)] = withScope {new CartesianRDD(sc, this, other)}

    groupBy

    將元素通過函數生成相應的 Key,數據就轉化為 Key-Value 格式,之后將 Key 相同的元素分為一組。

    函數實現如下:

    1)將用戶函數預處理:

    val cleanF = sc.clean(f)

    2)對數據 map 進行函數操作,最后再進行 groupByKey 分組操作。

    this.map(t => (cleanF(t), t)).groupByKey(p)
    • scala源碼

      def groupBy[K](f: T => K)(implicit kt: ClassTag[K]): RDD[(K, Iterable[T])] = withScope {groupBy[K](f, defaultPartitioner(this))}

    distinct

    對數據進行去重

    • scala源碼

      /*** Return a new RDD containing the distinct elements in this RDD.*/def distinct(numPartitions: Int)(implicit ord: Ordering[T] = null): RDD[T] = withScope {map(x => (x, null)).reduceByKey((x, y) => x, numPartitions).map(_._1)}/*** Return a new RDD containing the distinct elements in this RDD.*/def distinct(): RDD[T] = withScope {distinct(partitions.length)}

    subtract

    subtract相當于進行集合的差操作,RDD 1去除RDD 1和RDD 2交集中的所有元素;

    • scala源碼

      /*** Return an RDD with the elements from `this` that are not in `other`.** Uses `this` partitioner/partition size, because even if `other` is huge, the resulting* RDD will be <= us.*/def subtract(other: RDD[T]): RDD[T] = withScope {subtract(other, partitioner.getOrElse(new HashPartitioner(partitions.length)))}/*** Return an RDD with the elements from `this` that are not in `other`.*/def subtract(other: RDD[T], numPartitions: Int): RDD[T] = withScope {subtract(other, new HashPartitioner(numPartitions))}/*** Return an RDD with the elements from `this` that are not in `other`.*/def subtract(other: RDD[T],p: Partitioner)(implicit ord: Ordering[T] = null): RDD[T] = withScope {if (partitioner == Some(p)) {// Our partitioner knows how to handle T (which, since we have a partitioner, is// really (K, V)) so make a new Partitioner that will de-tuple our fake tuplesval p2 = new Partitioner() {override def numPartitions: Int = p.numPartitionsoverride def getPartition(k: Any): Int = p.getPartition(k.asInstanceOf[(Any, _)]._1)}

    sample

    sample 將 RDD 這個集合內的元素進行采樣,獲取所有元素的子集。用戶可以設定是否有放回的抽樣、百分比、隨機種子,進而決定采樣方式。內部實現是生成 SampledRDD(withReplacement, fraction, seed)。

    函數參數設置:

    withReplacement=true,表示有放回的抽樣。 withReplacement=false,表示無放回的抽樣。
    • scala源碼
    def sample(withReplacement: Boolean,fraction: Double,seed: Long = Utils.random.nextLong): RDD[T] = {require(fraction >= 0,s"Fraction must be nonnegative, but got ${fraction}")withScope {require(fraction >= 0.0, "Negative fraction value: " + fraction)if (withReplacement) {new PartitionwiseSampledRDD[T, T](this, new PoissonSampler[T](fraction), true, seed)} else {new PartitionwiseSampledRDD[T, T](this, new BernoulliSampler[T](fraction), true, seed)}}}

    takeSample

    takeSample()函數和上面的sample函數是一個原理,但是不使用相對比例采樣,而是按設定的采樣個數進行采樣,同時返回結果不再是RDD,而是相當于對采樣后的數據進行Collect(),返回結果集為單機的數組

    • scala源碼
    //返回集為數組def takeSample(withReplacement: Boolean,num: Int,seed: Long = Utils.random.nextLong): Array[T] = withScope {val numStDev = 10.0require(num >= 0, "Negative number of elements requested")require(num <= (Int.MaxValue - (numStDev * math.sqrt(Int.MaxValue)).toInt),"Cannot support a sample size > Int.MaxValue - " +s"$numStDev * math.sqrt(Int.MaxValue)")if (num == 0) {new Array[T](0)} else {val initialCount = this.count()if (initialCount == 0) {new Array[T](0)} else {val rand = new Random(seed)if (!withReplacement && num >= initialCount) {Utils.randomizeInPlace(this.collect(), rand)} else {val fraction = SamplingUtils.computeFractionForSampleSize(num, initialCount,withReplacement)var samples = this.sample(withReplacement, fraction, rand.nextInt()).collect()// If the first sample didn't turn out large enough, keep trying to take samples;// this shouldn't happen often because we use a big multiplier for the initial sizevar numIters = 0while (samples.length < num) {logWarning(s"Needed to re-sample due to insufficient sample size. Repeat #$numIters")samples = this.sample(withReplacement, fraction, rand.nextInt()).collect()numIters += 1}Utils.randomizeInPlace(samples, rand).take(num)}}}}

    mapValues

    針對(key, Value)型數據中的value進行map操作,而不對key進行處理

    • scala源碼
    /*** Pass each value in the key-value pair RDD through a map function without changing the keys;* this also retains the original RDD's partitioning.*/def mapValues[U](f: V => U): RDD[(K, U)] = self.withScope {val cleanF = self.context.clean(f)new MapPartitionsRDD[(K, U), (K, V)](self,(context, pid, iter) => iter.map { case (k, v) => (k, cleanF(v)) },preservesPartitioning = true)}

    combineByKey

    • scala源碼
    def combineByKey[C](createCombiner: V => C, //C不存在的情況下,比如通過V創建seq CmergeValue: (C, V) => C, //當C已經存在的情況下需要merge,比如把item V加入到seq C中,或者疊加mergeCombiners: (C, C) => C, //合并兩個Cpartitioner: Partitioner, //Partitioner,Shuffle時需要的PartitionermapSideCombine: Boolean = true, //為了減小傳輸量,很多 combine 可以在 map端先做,比如疊加,可以先在一個 partition 中把所有相同的 key 的 value 疊加,再 shuff le。//傳輸需要序列化,用戶可以自定義序列化類serializer: Serializer = null): RDD[(K, C)] = self.withScope {combineByKeyWithClassTag(createCombiner, mergeValue, mergeCombiners,partitioner, mapSideCombine, serializer)(null)}

    reduceByKey

    reduceByKey是比combineByKey更簡單的一種情況,只是兩個值合并成一個值 -------- *(Int,Int V) >> (Int, IntC)*
    • scala源碼
    /*** Merge the values for each key using an associative and commutative reduce function. This will* also perform the merging locally on each mapper before sending results to a reducer, similarly* to a "combiner" in MapReduce.*/def reduceByKey(partitioner: Partitioner, func: (V, V) => V): RDD[(K, V)] = self.withScope {combineByKeyWithClassTag[V]((v: V) => v, func, func, partitioner)}/*** Merge the values for each key using an associative and commutative reduce function. This will* also perform the merging locally on each mapper before sending results to a reducer, similarly* to a "combiner" in MapReduce. Output will be hash-partitioned with numPartitions partitions.*/def reduceByKey(func: (V, V) => V, numPartitions: Int): RDD[(K, V)] = self.withScope {reduceByKey(new HashPartitioner(numPartitions), func)}/*** Merge the values for each key using an associative and commutative reduce function. This will* also perform the merging locally on each mapper before sending results to a reducer, similarly* to a "combiner" in MapReduce. Output will be hash-partitioned with the existing partitioner/* parallelism level.*/def reduceByKey(func: (V, V) => V): RDD[(K, V)] = self.withScope {reduceByKey(defaultPartitioner(self), func)}

    partitionBy

    partitionBy函數對RDD進行分區操作;------ partitionBy(partitioner:Partitioner)

    • scala源碼
    /*** Return a copy of the RDD partitioned using the specified partitioner.*/def partitionBy(partitioner: Partitioner): RDD[(K, V)] = self.withScope {if (keyClass.isArray && partitioner.isInstanceOf[HashPartitioner]) {throw new SparkException("HashPartitioner cannot partition array keys.")}if (self.partitioner == Some(partitioner)) {self} else {new ShuffledRDD[K, V, V](self, partitioner)}}

    cogroup

    cogroup函數將兩個RDD進行協同劃分,對兩個RDD中的key-valuel類型的元素,每個RDD相同key的元素風別聚合為一個集合,并且返回兩個RDD中對應Key的元素集合的迭代器

    • scala源碼
    def cogroup[W1, W2, W3](other1: RDD[(K, W1)],other2: RDD[(K, W2)],other3: RDD[(K, W3)],partitioner: Partitioner): RDD[(K, (Iterable[V], Iterable[W1], Iterable[W2], Iterable[W3]))] = self.withScope {if (partitioner.isInstanceOf[HashPartitioner] && keyClass.isArray) {throw new SparkException("HashPartitioner cannot partition array keys.")}val cg = new CoGroupedRDD[K](Seq(self, other1, other2, other3), partitioner)cg.mapValues { case Array(vs, w1s, w2s, w3s) =>(vs.asInstanceOf[Iterable[V]],w1s.asInstanceOf[Iterable[W1]],w2s.asInstanceOf[Iterable[W2]],w3s.asInstanceOf[Iterable[W3]])}}

    join

    join 對兩個需要連接的 RDD 進行 cogroup函數操作,將相同 key 的數據能夠放到一個分區,在 cogroup 操作之后形成的新 RDD 對每個key 下的元素進行笛卡爾積的操作,返回的結果再展平,對應 key 下的所有元組形成一個集合。最后返回 RDD[(K, (V, W))]。

    • scala源碼
    def join[W](other: RDD[(K, W)], partitioner: Partitioner): RDD[(K, (V, W))] = self.withScope {this.cogroup(other, partitioner).flatMapValues( pair =>for (v <- pair._1.iterator; w <- pair._2.iterator) yield (v, w))}

    sortyByKey(sortBy)

    作用再(Key, Value)格式的數據上,根據Key進行升序或降序排序

    • scala源碼
    def sortByKey(ascending: Boolean = true, numPartitions: Int = self.partitions.length): RDD[(K, V)] = self.withScope{val part = new RangePartitioner(numPartitions, self, ascending)new ShuffledRDD[K, V, V](self, part).setKeyOrdering(if (ascending) ordering else ordering.reverse)}def sortBy[K](f: (T) => K,ascending: Boolean = true,numPartitions: Int = this.partitions.length)(implicit ord: Ordering[K], ctag: ClassTag[K]): RDD[T] = withScope {this.keyBy[K](f).sortByKey(ascending, numPartitions).values}

    Action算子(行動算子)

    本質上在Action算子中通過SparkContext觸發SparkContext提交job作業。Action 算子會觸發 Spark 提交作業(Job),并將數據輸出 Spark系統。

    foreach

    foreach對RDD中的每個元素都應用f函數操作,不返回RDD和Array,而返回Uint;(遍歷)

    • scala源碼
    def foreach(f: T => Unit): Unit = withScope {val cleanF = sc.clean(f)sc.runJob(this, (iter: Iterator[T]) => iter.foreach(cleanF))}

    saveAsTextFile

    函數將數據輸出,存儲到HDFS的制定目錄下

    saveAsObjectFile

    將風趣中的每10個元素組成一個Array,然后將這個Array序列化,映射為Null,BytesWritable(Y)的元素,寫入HDFS為SequenceFile的格式;

    map(x=>(NullWritable.get(),new BytesWritable(Utils.serialize(x))))

    colloect

    相當于toArray,collect將分布式的RDD返回為一個單機的scala Array數組,在這個數組上運用scala的函數式操作;


    左側方框代表 RDD 分區,右側方框代表單機內存中的數組。通過函數操作,將結果返回到 Driver 程序所在的節點,以數組形式存儲。

    collectAsMap

    collectAsMap對(K,V)型的RDD數據返回一個單機HashMap;
    對于重復K的RDD元素,后面的元素覆蓋前面的元素

    lookup

    Lookup函數對(Key,Value)型的RDD操作,返回指定Key對應的元素形成的Seq。 這個函數處理優化的部分在于,如果這個RDD包含分區器,則只會對應處理K所在的分區,然后返回由(K,V)形成的Seq。 如果RDD不包含分區器,則需要對全RDD元素進行暴力掃描處理,搜索指定K對應的元素。 ------- lookup(key:K):Seq[V]

    count

    count(計數器)返回整個RDD的元素個數

    defcount():Long=sc.runJob(this,Utils.getIteratorSize_).sum

    top

    top可返回最大的k個元素

    top(num:Int)(implicit ord:Ordering[T]):Array[T]
    • top返回最大的k個元素。
    • take返回最小的k個元素。
    • takeOrdered返回最小的k個元素,并且在返回的數組中保持元素的順序。
    • first相當于top(1)返回整個RDD中的前k個元素,可以定義排序的方式Ordering[T],返回的是一個含前k個元素的數組.

    reduce

    reduce函數相當于對RDD中的元素進行reduceLeft函數的操作; ---- Some(iter.reduceLeft(cleanF))

    reduceLeft先對兩個元素<K,V>進行reduce函數操作,然后將結果和迭代器取出的下一個元素<k,V>進行reduce函數操作,直到迭代器遍歷完所有元素,得到最后結果。在RDD中,先對每個分區中的所有元素<K,V>的集合分別進行reduceLeft。 每個分區形成的結果相當于一個元素<K,V>,再對這個結果集合進行reduceleft操作;

    fold

    fold和reduce的原理相同,但是與reduce不同,相當于每個reduce時,迭代器取的第一個元素是zeroValue;

    控制算子

    控制算子有三種,cache,persist,checkpoint,以上算子都可以將RDD持久化,持久化的單位是partition。cache和persist都是懶執行的。必須有一個action類算子觸發執行。checkpoint算子不僅能將RDD持久化到磁盤,還能切斷RDD之間的依賴關系;

    cache

    cache默認將RDD的數據持久化到內存中,相當與persist(MEMORY_ONLY)函數的功能;

    chche () = persist()=persist(StorageLevel.Memory_Only)

    persist

    可以指定持久話的級別,最常用的是MEMORY_ONLTY和MEMORY_AND_DISK;"_2"表示副本數;

    持久化有如下級別:

    cache和persist的注意事項

    • cache和persist都是懶執行,必須有一個action類算子觸發執行。
    • cache和persist算子的返回值可以賦值給一個變量,在其他job中直接使用這個變量就是使用持久化的數據了。持久化的單位是partition
    • cache和persist算子后不能立即緊跟action算子。

    checkpoint

    checkpoint將RDD持久化到磁盤,還可以切斷RDD之間的依賴關系

    • checkpoint 的執行原理:

      • 當RDD的job執行完畢后,會從finalRDD從后往前回溯。
      • 當回溯到某一個RDD調用了checkpoint方法,會對當前的RDD做一個標記。
      • Spark框架會自動啟動一個新的job,重新計算這個RDD的數據,將數據持久化到HDFS上。
    • 優化:對RDD執行checkpoint之前,最好對這個RDD先執行cache,這樣新啟動的job只需要將內存中的數據拷貝導HDFS上就可以,省去重新計算這一步;

    例如:

    SparkConf conf = new SparkConf();conf.setMaster("local").setAppName("checkpoint");JavaSparkContext sc = new JavaSparkContext(conf);sc.setCheckpointDir("./checkpoint");JavaRDD<Integer> parallelize = sc.parallelize(Arrays.asList(1,2,3));parallelize.checkpoint();parallelize.count();sc.stop();

    總結

    以上是生活随笔為你收集整理的Spark 常用算子详解(转换算子、行动算子、控制算子)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    亚洲在线精品 | 在线视频久久 | 日韩欧美在线高清 | 视频国产在线 | 久久久国际精品 | 美女网站视频久久 | 五月婷久久 | 免费在线观看污 | 国产成人精品久久久久蜜臀 | 久草在线网址 | 精品国产乱码久久久久 | 国产精品女教师 | 黄色免费网站 | 伊人激情综合 | 91色综合 | 亚洲精品91天天久久人人 | 国产精品完整版 | 国产日韩欧美自拍 | 久久久久久久久久久久电影 | 国产一线二线三线性视频 | 日韩精品三区四区 | 国产麻豆精品传媒av国产下载 | 一区二区三区电影 | 91精彩视频 | 色诱亚洲精品久久久久久 | 亚洲人在线| 久草a在线 | 久草免费看 | 西西大胆啪啪 | 国产一级性生活 | 97在线资源 | 欧美精品久久人人躁人人爽 | 久久影院精品 | 久久国产精品99久久久久久丝袜 | 亚洲国产精品激情在线观看 | 日韩女同一区二区三区在线观看 | 在线观看中文字幕dvd播放 | 国产九色在线播放九色 | 亚洲在线a| 黄色小说视频网站 | 最新中文字幕 | 成人黄色在线电影 | av大全在线免费观看 | 免费视频一级片 | 国产精品v欧美精品v日韩 | 91精品办公室少妇高潮对白 | 欧美成人亚洲成人 | 久久视频这里有久久精品视频11 | 国产乱码精品一区二区三区介绍 | 久久五月天综合 | 国产精品免费在线视频 | 日日夜夜狠狠操 | 99久久国产免费看 | 96av在线视频 | 超碰97免费 | 免费福利视频导航 | 在线亚洲播放 | 五月婷婷在线视频观看 | 亚洲一区日韩在线 | 五月天久久久久 | 国产亚洲综合性久久久影院 | 中文在线天堂资源 | 欧美性春潮 | 91在线看 | 国产精品视频久久久 | 精品国产精品久久 | 欧美日产一区 | 色噜噜狠狠色综合中国 | 超碰在线人人 | 久久在线影院 | 亚洲精品在线视频 | av黄色成人 | 亚洲黄色免费 | 久久伊人综合 | 色网址99| 黄色毛片网站在线观看 | 91亚洲精品久久久蜜桃网站 | 808电影 | 亚洲人成网站精品片在线观看 | 久国产在线播放 | 国产精品亚洲片夜色在线 | 亚洲自拍偷拍色图 | 欧美国产日韩在线视频 | 99久久精品一区二区成人 | 一区二区三区四区五区在线视频 | 天堂网一区二区三区 | 免费亚洲一区二区 | 天天做天天爱天天综合网 | 久久国产精品精品国产色婷婷 | 超碰官网 | 久久久久久久久网站 | 99久久99视频 | 国产精品视频不卡 | 久久97久久 | 91看片网址| 精品久久久久久国产91 | 六月激情久久 | 九草视频在线观看 | 欧美精品v国产精品v日韩精品 | 国模视频一区二区 | 国产精品视频在线看 | 美女黄频视频大全 | 久久精品屋 | 日韩中文三级 | 天天搞天天干天天色 | 韩国在线视频一区 | 中文字幕免费国产精品 | 又粗又长又大又爽又黄少妇毛片 | 91av在| 草久久av| 中文av在线播放 | 日韩色在线观看 | 天天综合成人 | 国产小视频网站 | 天天干,天天插 | 丁香激情网| 国产1区在线 | 天天干,夜夜爽 | 精品国产乱码久久久久久久 | 婷婷激情小说网 | 日韩欧美有码在线 | 日韩精品免费 | 免费美女久久99 | 国产黄色av网站 | 免费观看一区二区三区视频 | 免费视频91蜜桃 | 激情图片qvod | 五月天视频网站 | 丝袜美腿亚洲 | 六月丁香激情综合色啪小说 | 天天色天天色 | 国产精品自产拍在线观看 | 激情在线五月天 | 91亚洲永久精品 | 国产精品高潮呻吟久久久久 | 日韩精品中文字幕一区二区 | 亚洲精品国久久99热 | 91精品天码美女少妇 | 特级aaa毛片 | 午夜久久久久久久久 | 欧美日韩在线观看一区 | 欧美日韩精品免费观看视频 | 成人国产综合 | 午夜电影 电影 | 日韩精品一区二区免费视频 | 国产精品人人做人人爽人人添 | 国产精品福利午夜在线观看 | 丁香综合av | 国产精品系列在线播放 | 亚洲欧洲精品久久 | 日韩网站在线看片你懂的 | 免费看精品久久片 | 综合色在线观看 | 麻豆94tv免费版| 久久国产手机看片 | 久久免费福利视频 | 美女黄频在线观看 | 国产乱码精品一区二区蜜臀 | 亚洲国产精品电影在线观看 | 婷婷丁香九月 | 亚洲精选在线观看 | 婷婷亚洲五月 | 色综合久久久久久中文网 | 日韩在线小视频 | 国产精品成人免费一区久久羞羞 | 爱爱av网站 | av大全在线| 日女人免费视频 | 在线观看完整版免费 | 久久在线精品 | 天堂av一区二区 | 奇米影视777影音先锋 | 在线观看中文字幕第一页 | 欧美黑人猛交 | 久草久热 | 日韩精品专区 | 国产在线观看污片 | 国产麻豆视频在线观看 | 免费av大片 | 国产午夜精品视频 | www.福利视频 | 美女黄网久久 | 91精品国产一区二区三区 | 夜夜躁日日躁狠狠躁 | 麻豆91视频| 色婷婷在线视频 | 免费在线激情电影 | 四虎成人精品永久免费av | 综合视频在线 | 免费成人短视频 | 依人成人综合网 | 国产专区在线视频 | 96久久精品 | 午夜视频导航 | 91av视频在线观看免费 | av一级片网站 | 日韩国产精品毛片 | 免费观看9x视频网站在线观看 | 91久久电影 | 久久国产午夜精品理论片最新版本 | 国产精品免费不 | .精品久久久麻豆国产精品 亚洲va欧美 | 欧美激情综合色综合啪啪五月 | 久久视频精品在线观看 | 亚洲精品免费观看视频 | av片免费播放 | 狠狠网站 | 深爱婷婷久久综合 | 亚洲区另类春色综合小说校园片 | 人人爱人人射 | 婷婷色吧| 夜夜天天干 | 国产精品乱码久久久久久1区2区 | 欧美日韩伦理在线 | 中文字幕中文字幕中文字幕 | 欧美电影黄色 | 国产在线观看中文字幕 | 亚洲免费在线观看视频 | 天堂va在线高清一区 | 久久影院精品 | 欧美午夜精品久久久久久浪潮 | 国产精品乱码一区二三区 | 久久96国产精品久久99漫画 | 91av视频在线免费观看 | 91麻豆精品国产91久久久无需广告 | 中文字幕在线看视频国产 | 91中文字幕在线播放 | 在线亚洲精品 | 99久久久国产免费 | 中文字幕在线视频一区二区三区 | 成人小视频在线观看免费 | 日韩激情在线视频 | 日韩精品一区二区三区在线视频 | 黄色小网站在线 | 日韩电影一区二区在线 | 一区二区三区国产欧美 | 国产五十路毛片 | av成人免费在线 | 少妇bbb搡bbbb搡bbbb′ | av爱干| 在线欧美小视频 | 成年人在线看片 | 在线观看av的网站 | 国产成人av一区二区三区在线观看 | 在线视频一区二区 | 久久不卡电影 | 欧美大片在线观看一区 | 国内精品美女在线观看 | 国产成人精品一区二区三区网站观看 | 成人av在线影院 | av一本久道久久波多野结衣 | 免费人人干 | 蜜臀av性久久久久av蜜臀三区 | 麻豆视频在线观看免费 | 久久久精品 一区二区三区 国产99视频在线观看 | 亚洲视频在线免费看 | 免费又黄又爽视频 | 欧美另类美少妇69xxxx | 成人av资源在线 | 免费看一级黄色大全 | 国产精品久久久久久69 | 国产欧美综合视频 | 国产日韩精品一区二区在线观看播放 | 日韩高清无线码2023 | 玖玖色在线观看 | 日韩精品在线播放 | 天无日天天操天天干 | 综合久久综合久久 | 欧美一区二区三区四区夜夜大片 | 91在线日本| 久久精品久久精品久久39 | 成人久久综合 | 久久国内免费视频 | 国产精品一区二区三区四 | 精品国产aⅴ一区二区三区 在线直播av | 亚洲人毛片 | 久久区二区 | a黄色片在线观看 | 精品视频免费久久久看 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 日韩欧美电影网 | 综合色在线观看 | 亚洲国产电影在线观看 | 九九在线精品视频 | 超碰97免费观看 | 午夜精品一区二区三区四区 | 麻豆果冻剧传媒在线播放 | 99久久婷婷国产精品综合 | 成人av在线影视 | 国产精品久久久久一区 | 中文字幕成人在线观看 | 成年人在线观看网站 | 在线观看国产福利片 | 黄色在线视频网址 | 狠狠操夜夜操 | 日韩中文字幕国产 | 欧美福利网站 | 9色在线视频 | 伊人视频 | 欧美性黑人 | 超碰在线人 | 黄网站www | 成人亚洲精品久久久久 | 日韩av手机在线观看 | 国产片免费在线观看视频 | 韩国av电影在线观看 | 成人黄色视| 97免费视频在线 | 亚洲高清视频在线观看免费 | 亚洲每日更新 | 国产亚洲精品久 | 亚洲国产99 | 波多野结衣视频一区 | 波多野结衣视频一区二区 | 精品福利网 | 亚洲最大色 | 一区二区三区免费 | 西西444www高清大胆 | 久久久久久久久网站 | 99久久精品免费一区 | 亚洲高清视频在线观看免费 | 一区二区毛片 | 97超碰在线免费观看 | 成年人app网址 | 天天操天天射天天添 | 日韩久久视频 | 国产一区电影在线观看 | 亚洲天天干| 日韩av手机在线观看 | 日本中文字幕视频 | 久久成人午夜视频 | 欧洲激情在线 | 91在线视频播放 | 国产精品一区二区美女视频免费看 | 日韩va在线观看 | 欧美一二区视频 | 99精品视频观看 | 国产精选在线观看 | 欧美精品久久久久久久久老牛影院 | 精品一区二区在线看 | 天天操天天曰 | 九九热中文字幕 | 精品久久久久久国产偷窥 | 亚洲国产中文字幕在线视频综合 | 亚洲成人第一区 | 色偷偷男人的天堂av | 日韩av电影网站在线观看 | 狠狠狠狠狠狠天天爱 | 99精品免费网 | 狠狠色噜噜狠狠狠合久 | 成 人 免费 黄 色 视频 | 久久精品视频在线观看免费 | 久久免费看毛片 | 激情丁香月 | 999久久国产 | 久亚洲精品| 天天综合网在线观看 | 国内久久 | 日韩黄色一区 | 亚洲国产精品视频 | 久久五月激情 | 狠狠色狠狠色 | 成人蜜桃网 | 一区二区精品视频 | 综合色站导航 | 91黄色在线看 | 中文字幕免费在线 | 中国一级特黄毛片大片久久 | 久久再线视频 | 中文字幕亚洲在线观看 | 亚洲国产精彩中文乱码av | 一级a性色生活片久久毛片波多野 | 国产精品白虎 | 色九色| 在线欧美小视频 | 欧美成年人在线观看 | 免费欧美 | 成人av亚洲 | 久久久av免费 | 国产精品免费久久久 | 国产午夜在线 | 久久综合久久综合久久综合 | 日韩欧美在线一区 | 久久爱影视i | 亚洲日韩中文字幕 | 久草视频在线免费 | 狠狠色噜噜狠狠狠 | 亚洲最新av网站 | 久久国产经典视频 | 国产馆在线播放 | 天天夜夜狠狠操 | 亚洲欧美国产精品久久久久 | 成年人免费在线观看网站 | 91亚洲在线 | 婷婷在线网站 | 日本爱爱片 | 999视频网 | 青春草视频 | 欧美日韩高清在线一区 | 欧美日韩成人 | 国产一区久久久 | 99久久精品免费一区 | 国产精品9999久久久久仙踪林 | 亚洲成人黄色在线观看 | 久久久免费在线观看 | 久久久久99精品成人片三人毛片 | 免费看一级一片 | 国产精品美女久久久网av | 九九久久在线看 | 精品国产一区二区三区不卡 | 日韩特黄一级欧美毛片特黄 | www.天天成人国产电影 | 久久久久久国产精品亚洲78 | 夜夜操狠狠操 | 又黄又刺激视频 | 久久久综合精品 | 天堂av色婷婷一区二区三区 | 亚洲国产69| 久久视频 | 久久久久看片 | 久久久久久久久久亚洲精品 | 午夜色站 | 久久深夜福利免费观看 | 91精品啪在线观看国产 | 中文字幕影视 | 亚洲国产中文字幕在线视频综合 | 啪啪小视频网站 | www.久久精品视频 | 在线视频 91 | 国产美女免费观看 | 亚洲在线视频播放 | 又黄又爽又色无遮挡免费 | 美女视频久久久 | 二区三区视频 | 亚洲va欧美va | 日韩av快播电影网 | 国产 一区二区三区 在线 | 亚洲视频久久 | 在线看v片| 国产精品一区二区三区久久久 | 中文字幕一区二区在线播放 | 日韩精品中文字幕在线观看 | 精品毛片在线 | 国产老熟 | 婷婷六月激情 | 91精品国产自产老师啪 | 天天弄天天干 | 久久久久激情视频 | 免费欧美 | 99在线精品观看 | 国产免费亚洲高清 | 欧美a级一区二区 | 久久婷婷色 | 日韩在线免费视频观看 | 精品uu| 亚洲国产电影在线观看 | 久久成人麻豆午夜电影 | 日日天天| 中文字幕 国产视频 | 国产成人区 | 日韩精品欧美专区 | 天堂在线成人 | 中文字幕在线第一页 | 亚洲第一成网站 | 亚洲 欧美 变态 国产 另类 | 日韩一区二区三区免费视频 | av高清在线| 草在线| 午夜精品久久久久久久99热影院 | 国产免费观看久久黄 | 国产精品欧美久久久久天天影视 | 亚洲丝袜中文 | 精品国产91亚洲一区二区三区www | 国产精品99蜜臀久久不卡二区 | 麻豆影视在线播放 | 免费看久久久 | 国产在线精品播放 | 精品一区中文字幕 | 97精品在线视频 | 亚洲日本韩国一区二区 | 亚洲三级网站 | 日日爱av| 中中文字幕av在线 | 中文字幕乱偷在线 | 天天操夜夜看 | 午夜精品福利在线 | 国产第一福利网 | 国产精品入口麻豆www | 天天操天天操天天操天天操天天操天天操 | 最近高清中文在线字幕在线观看 | 久久久久久欧美二区电影网 | 国产精品视频免费在线观看 | 99色| 国产 日韩 欧美 自拍 | 国内精品久久久久影院优 | 色午夜影院 | 久久久久国产精品免费网站 | 日本aa在线 | 婷婷久操 | 日韩精品第一区 | av三级av| 91探花视频 | 国产一区在线视频 | 99婷婷| 欧美精品国产综合久久 | 久草男人天堂 | 综合网天天射 | 久久艹国产视频 | 精品国产一区二区三区噜噜噜 | 国产精品11| 美女免费视频黄 | 欧美激情精品久久久久久变态 | 成人免费视频网 | 精品久久一区二区 | av一本久道久久波多野结衣 | 在线99热 | 日韩av一区二区三区四区 | 亚洲乱码在线观看 | 国产高清福利在线 | 麻豆 91 在线 | 日韩av视屏 | 欧美做受高潮电影o | 黄色大全免费观看 | 久久99久久99精品免观看粉嫩 | 免费视频一区 | 精品国产一区二区三区久久久蜜月 | 伊人色综合久久天天网 | 成人四虎影院 | 亚洲日本韩国一区二区 | 日韩超碰在线 | 色综合久久久久综合99 | 亚洲黄色一级电影 | 亚洲国产中文字幕在线观看 | 国产精品短视频 | 欧美另类高潮 | 精品一区二区在线免费观看 | 久久精品爱爱视频 | 久久久精品网站 | 六月激情久久 | 日韩欧美电影在线 | 日本成人黄色片 | 91视频91蝌蚪 | 日韩免费| 天天曰天天 | 精品国产精品国产偷麻豆 | 五月婷婷久 | 国产1区2区3区在线 亚洲自拍偷拍色图 | 欧美日韩视频一区二区三区 | 婷婷六月中文字幕 | 91丨九色丨国产在线观看 | 欧美日韩裸体免费视频 | 国产精品99精品久久免费 | 一二区av| 91香蕉久久| 91亚洲永久精品 | 国产精品成人在线观看 | 天天av在线播放 | av免费观看在线 | 免费a一级 | 国产精品欧美日韩在线观看 | 亚洲黄色激情小说 | 天堂av网址| 婷婷激情五月 | 欧美在线aaa| 天天干夜夜 | 免费麻豆视频 | 国产午夜精品一区二区三区欧美 | 狠狠色丁香九九婷婷综合五月 | 最新成人在线 | 伊人亚洲综合网 | 久久成年人 | 亚洲 欧美 综合 在线 精品 | 伊人久久精品久久亚洲一区 | 国产丝袜美腿在线 | 激情综合狠狠 | 国产免费久久精品 | 中文字幕在线观看你懂的 | 日韩精品免费在线视频 | 日韩免费一级a毛片在线播放一级 | 亚洲欧洲中文日韩久久av乱码 | 成人av日韩 | 日本久久不卡视频 | 亚洲精品在线观看网站 | 午夜av日韩 | 99久久成人 | 一级黄色毛片 | 麻豆精品视频在线观看免费 | 日韩高清精品免费观看 | 一区免费视频 | 最近中文字幕免费av | 黄色视屏av | 91视频中文字幕 | 超碰在线日本 | 日本99干网 | 亚洲精品1区2区3区 超碰成人网 | 国产精品婷婷 | 黄色小说视频在线 | 午夜美女wwww | 日韩videos高潮hd | 日韩a在线播放 | 久久黄色网址 | 婷婷视频在线观看 | 中文字幕欧美激情 | 看片在线亚洲 | 国产资源免费 | 国产黄色片一级三级 | 国产精品一区一区三区 | 97视频精品 | 可以免费看av | 高清av免费一区中文字幕 | 久久综合九色综合欧美就去吻 | 国产福利一区二区三区视频 | 欧美日韩视频一区二区 | 精品视频不卡 | 国际精品久久久 | av中文字幕网 | 免费看污网站 | 91理论电影 | 国产视频在线观看一区 | 日韩在线视频免费播放 | 亚洲美女免费视频 | 亚洲精品久久久蜜桃直播 | 不卡的一区二区三区 | 国产99中文字幕 | 日韩视频中文字幕在线观看 | 日韩 国产 | 激情丁香综合五月 | 99日韩精品 | 日韩在线观看中文 | 国产精品美女久久久久久久 | 美女搞黄国产视频网站 | 久久艹国产视频 | 免费看污在线观看 | 在线观看视频免费播放 | 91在线在线观看 | 久久久久一区二区三区四区 | 欧美性生活一级片 | av性网站| 久久一区二区免费视频 | av中文天堂| 国产精品一区在线观看 | 亚洲欧美日韩中文在线 | 久久久久久久久久久久亚洲 | 精品一区久久 | 国产精品网红直播 | 91成人精品一区在线播放69 | 亚洲春色综合另类校园电影 | 九九免费在线观看视频 | 久久九九九九 | 亚洲成年人在线播放 | 午夜久久影院 | 中文十次啦 | 久久爱资源网 | 婷婷五情天综123 | 天堂视频中文在线 | 久久久夜色 | 精品在线观看视频 | 欧美男男tv网站 | 免费在线播放 | 国产日产亚洲精华av | 日韩3区 | 久久人人精品 | 正在播放 国产精品 | 黄色av三级在线 | 国产网红在线 | 91av99 | 国产又粗又猛又黄又爽 | av三级在线免费观看 | 波多野结衣视频一区 | 丁香婷婷深情五月亚洲 | 亚洲成a人片在线观看网站口工 | 在线观看的av | 国产中文字幕在线免费观看 | 在线观看 国产 | av一级片在线观看 | 欧美成a人片在线观看久 | 久久久五月天 | 免费视频久久久久 | 国产福利一区二区三区视频 | 国产精品久久久久久久久久久久冷 | 91福利影院在线观看 | 国产高清综合 | 狠狠色综合网站久久久久久久 | 伊甸园av在线 | 久久久久久免费 | 成年人免费电影在线观看 | 日韩剧| 国产资源在线视频 | 精品国产99国产精品 | 久久久在线免费观看 | 欧洲亚洲国产视频 | 麻豆视频免费在线播放 | 夜夜操夜夜干 | 福利一区在线视频 | 毛片激情永久免费 | 亚洲成人黄色在线观看 | 欧美va天堂va视频va在线 | 日韩啪啪小视频 | 免费在线观看成年人视频 | 国产不卡视频在线 | www.午夜视频| 国产亚洲日本 | www.国产毛片| 日韩欧美69 | 国产999视频在线观看 | 国产91在线观看 | 久久久香蕉视频 | 欧美久久九九 | 亚洲第一av在线播放 | av观看在线观看 | 日本在线观看一区 | 亚洲精品小区久久久久久 | 免费裸体视频网 | 久久国产精品99久久久久久丝袜 | 伊人狠狠操 | 欧美99久久 | 99久久久久免费精品国产 | 九九视频在线播放 | 99精品美女 | 日本xxxx裸体xxxx17 | 免费三级黄色片 | 日韩精品不卡在线 | 福利一区二区 | 国产va精品免费观看 | 久久久免费看片 | 狠狠的操| 在线免费三级 | 免费看日韩 | 国产精品视频内 | 国产成人精品一二三区 | 久久观看最新视频 | 久久久受www免费人成 | 一本到视频在线观看 | 久久99精品国产麻豆宅宅 | 久久视频网址 | 久久艹在线 | 国产97碰免费视频 | 国产精品毛片久久久久久 | 久草在在线视频 | 中文字幕丝袜制服 | 国模视频一区二区 | av动态图片 | 久草在线在线 | 国产精品video | 精品国产乱码久久久久 | 天天色中文 | 天天爽天天射 | 91麻豆福利| 欧美一级激情 | 久久久久久亚洲精品 | 中国成人一区 | 欧美日韩二区三区 | 四虎海外影库www4hu | 91麻豆.com| 久久精品视频3 | 日韩黄色大片在线观看 | 99热这里只有精品国产首页 | 九九九毛片 | 日韩电影中文字幕在线观看 | 成人小视频在线 | 天天操天天添天天吹 | 亚洲成av人片一区二区梦乃 | 国产短视频在线播放 | 天天干夜夜擦 | 国产永久免费高清在线观看视频 | 高清不卡一区二区三区 | 国产精品成人自产拍在线观看 | 国产视频18 | 99在线精品免费视频九九视 | 国产精品一区二区免费 | 日韩理论在线视频 | 日韩精品极品视频 | 日日操天天射 | 国产亚洲精品久久久久久移动网络 | 丁香六月在线 | 福利片免费看 | 韩国av一区二区三区 | 美女在线免费视频 | 中文字幕免费高清 | 在线视频婷婷 | 久久久精品国产一区二区三区 | 欧美成年黄网站色视频 | 天天天操操操 | 99精品乱码国产在线观看 | 亚洲国产视频在线 | 超碰com| 在线精品亚洲一区二区 | 欧美福利片在线观看 | 欧美日韩不卡在线 | 91香蕉亚洲精品 | 日韩理论影院 | 一区二区视频免费在线观看 | 人人狠 | av韩国在线| 久久一区国产 | 天天射天天舔天天干 | 日韩精品一区二区三区电影 | 久免费 | 久久精品a | 一本一本久久a久久精品综合小说 | av天天在线观看 | 黄色软件在线看 | 欧美成年人在线视频 | 黄色成人av | 在线播放视频一区 | av资源在线观看 | 亚洲精品中文在线资源 | 在线看污网站 | 久久国产精品久久精品 | 一区二区三区 亚洲 | 免费看麻豆 | 日韩一区二区三区观看 | 国产精品1区2区在线观看 | 日韩av一区二区三区 | 不卡精品视频 | 久久视频热 | 免费午夜视频在线观看 | 日韩欧美精品一区二区 | 久久精品99国产精品酒店日本 | 国内精品美女在线观看 | 99久久99视频 | 天天操天天谢 | 亚洲免费成人 | 又黄又刺激的网站 | 99精品国产福利在线观看免费 | 亚洲高清av在线 | 婷婷中文字幕 | 在线免费观看一区二区三区 | 久操久 | 在线观看久 | 亚洲国产福利视频 | 久草在线免费看视频 | 天天干天天操 | 91人人射 | 超级碰碰碰视频 | 免费视频一二三 | 国产高清视频色在线www | 色黄视频免费观看 | 日韩av一区二区在线 | av在线收看| 欧美亚洲精品在线观看 | 天天干天天操天天搞 | 免费视频91蜜桃 | 粉嫩一区二区三区粉嫩91 | 91精品久久久久久久91蜜桃 | 91综合视频在线观看 | 久久国产片 | 日韩av一区二区三区在线观看 | 亚洲永久精品国产 | 精品国产欧美 | 亚洲国产免费 | 一区二区三区在线免费播放 | 欧美日韩免费一区二区 | 久久亚洲精品国产亚洲老地址 | 视频在线观看入口黄最新永久免费国产 | 激情久久综合 | 日韩av中文 | 日韩精品首页 | 欧美超碰在线 | 香蕉久久久久久久 | 国产不卡高清 | 一区中文字幕 | 91福利国产在线观看 | 成人观看| 国产电影一区二区三区四区 | 欧美在线观看禁18 | 色无五月| 天天操天天舔天天干 | 999色视频 | 国产中文在线视频 | 久久久久久黄 | 免费看色网站 | 日韩精品一区二区三区电影 | a级国产乱理论片在线观看 伊人宗合网 | 丁香婷婷网 | 在线观看黄色国产 | 美女网站色免费 | а天堂中文最新一区二区三区 | 日韩欧美一二三 | 久香蕉| 亚洲一区久久久 | 国产中文字幕视频在线 | 美国av大片 | 久久系列 | aaa日本高清在线播放免费观看 | 国产高清成人av | 国产一级a毛片视频爆浆 | 亚洲国产一区二区精品专区 | 韩国av一区二区 | 丁香电影小说免费视频观看 | 在线精品亚洲 | 国产69精品久久久久久久久久 | 成年人免费看的视频 | 91av官网| h视频日本 | 日韩一二三 | 激情欧美日韩一区二区 | 天堂在线v | www.com黄色 | 免费91麻豆精品国产自产在线观看 | 91亚洲精品在线 | 五月花丁香婷婷 | 国产精品成人一区二区三区吃奶 | 久草在线久草在线2 | av网站手机在线观看 | 午夜精品福利一区二区三区蜜桃 | 一二区电影 | 午夜视频一区二区三区 | 91在线看| 欧美福利视频 | 亚洲最新av在线 | 五月婷婷网站 | 久草com | 天天做天天射 | 日韩另类在线 | 国产亚洲精品日韩在线tv黄 | www.久久久.com | 国产精品丝袜久久久久久久不卡 | 久久国产网站 | 91在线看| 亚洲天堂网在线观看视频 | 天天干夜夜爱 | 国产精品色视频 | 日韩一级电影网站 | 久久亚洲福利视频 | 热精品 | 国产色一区 | 色天天综合久久久久综合片 | 国产成人av一区二区三区在线观看 | 涩涩资源网 | 91丨九色丨丝袜 | 99在线热播精品免费99热 | 99热这里只有精品在线观看 | 日韩亚洲在线视频 | 欧美精品久久久久久久久久丰满 | 四虎影院在线观看av | 在线黄色国产电影 | 97国产大学生情侣白嫩酒店 | 久热免费在线观看 | wwwwww色| 久久久久激情电影 | 国产成人在线一区 | 国产精品午夜8888 | 久久国产精品免费一区 | 久久综合9988久久爱 | 久久综合精品国产一区二区三区 | 天干啦夜天干天干在线线 | 伊人影院99 | 国产成人av福利 | 深爱激情五月综合 | 久久久久久久av麻豆果冻 | 欧美 日韩 国产 中文字幕 | 男女全黄一级一级高潮免费看 | 亚洲国产精久久久久久久 | 国产黄在线看 | 色综合久久88色综合天天免费 | 亚洲在线国产 | 欧美在线观看禁18 | 一级片免费在线 | 99这里精品 | 97超碰超碰久久福利超碰 | 免费av片在线 | 97精品超碰一区二区三区 | 色成人亚洲 | 啪啪肉肉污av国网站 | 亚洲欧美视频网站 | 午夜黄网 | 在线播放你懂 | 97超碰在线播放 | 成人亚洲综合 | 四虎影视成人永久免费观看视频 | 免费看的黄色录像 | 国产1区在线观看 | 日日夜夜爱 | 99久久婷婷国产一区二区三区 | 中文字幕视频在线播放 | 久久久国产电影 | 中文字幕日韩一区二区三区不卡 | www.久热| 在线看欧美 | 中文字幕二区在线观看 | 伊人五月天婷婷 | 国产黄色大片免费看 | 久久久精品 | 在线观看一区二区视频 | 免费特级黄色片 | 精品一区 精品二区 | 欧美二区三区91 | 亚洲永久精品在线观看 | 久久人人爽人人爽人人片av免费 | 亚洲欧美日韩精品一区二区 | 成人亚洲精品国产www | 日韩免费大片 | 不卡av在线播放 | 亚洲a成人v | 波多野结衣在线播放一区 | 午夜精品久久久久久久99热影院 | 国产精品96久久久久久吹潮 |