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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Spark RDD使用详解5--Action算子

發布時間:2024/1/17 编程问答 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spark RDD使用详解5--Action算子 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本質上在Actions算子中通過SparkContext執行提交作業的runJob操作,觸發了RDD DAG的執行。?
根據Action算子的輸出空間將Action算子進行分類:無輸出、 HDFS、 Scala集合和數據類型。

無輸出

foreach

對RDD中的每個元素都應用f函數操作,不返回RDD和Array,而是返回Uint。?

圖中,foreach算子通過用戶自定義函數對每個數據項進行操作。 本例中自定義函數為println,控制臺打印所有數據項。

源碼:

?

?
  • /**

  • * Applies a function f to all elements of this RDD.

  • */

  • def foreach(f: T => Unit) {

  • val cleanF = sc.clean(f)

  • sc.runJob(this, (iter: Iterator[T]) => iter.foreach(cleanF))

  • }

  • ?

    HDFS

    (1)saveAsTextFile

    函數將數據輸出,存儲到HDFS的指定目錄。將RDD中的每個元素映射轉變為(Null,x.toString),然后再將其寫入HDFS。?

    圖中,左側的方框代表RDD分區,右側方框代表HDFS的Block。 通過函數將RDD的每個分區存儲為HDFS中的一個Block。

    源碼:

    ?

    ?
  • /**

  • * Save this RDD as a text file, using string representations of elements.

  • */

  • def saveAsTextFile(path: String) {

  • // https://issues.apache.org/jira/browse/SPARK-2075

  • //

  • // NullWritable is a `Comparable` in Hadoop 1.+, so the compiler cannot find an implicit

  • // Ordering for it and will use the default `null`. However, it's a `Comparable[NullWritable]`

  • // in Hadoop 2.+, so the compiler will call the implicit `Ordering.ordered` method to create an

  • // Ordering for `NullWritable`. That's why the compiler will generate different anonymous

  • // classes for `saveAsTextFile` in Hadoop 1.+ and Hadoop 2.+.

  • //

  • // Therefore, here we provide an explicit Ordering `null` to make sure the compiler generate

  • // same bytecodes for `saveAsTextFile`.

  • val nullWritableClassTag = implicitly[ClassTag[NullWritable]]

  • val textClassTag = implicitly[ClassTag[Text]]

  • val r = this.mapPartitions { iter =>

  • val text = new Text()

  • iter.map { x =>

  • text.set(x.toString)

  • (NullWritable.get(), text)

  • }

  • }

  • RDD.rddToPairRDDFunctions(r)(nullWritableClassTag, textClassTag, null)

  • .saveAsHadoopFile[TextOutputFormat[NullWritable, Text]](path)

  • }

  • ?
  • /**

  • * Save this RDD as a compressed text file, using string representations of elements.

  • */

  • def saveAsTextFile(path: String, codec: Class[_ <: CompressionCodec]) {

  • // https://issues.apache.org/jira/browse/SPARK-2075

  • val nullWritableClassTag = implicitly[ClassTag[NullWritable]]

  • val textClassTag = implicitly[ClassTag[Text]]

  • val r = this.mapPartitions { iter =>

  • val text = new Text()

  • iter.map { x =>

  • text.set(x.toString)

  • (NullWritable.get(), text)

  • }

  • }

  • RDD.rddToPairRDDFunctions(r)(nullWritableClassTag, textClassTag, null)

  • .saveAsHadoopFile[TextOutputFormat[NullWritable, Text]](path, codec)

  • }

  • ?

    (2)saveAsObjectFile

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

    圖中,左側方框代表RDD分區,右側方框代表HDFS的Block。 通過函數將RDD的每個分區存儲為HDFS上的一個Block。

    源碼:

    ?

    ?
  • /**

  • * Save this RDD as a SequenceFile of serialized objects.

  • */

  • def saveAsObjectFile(path: String) {

  • this.mapPartitions(iter => iter.grouped(10).map(_.toArray))

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

  • .saveAsSequenceFile(path)

  • }

  • ?

    Scala集合和數據類型

    (1)collect

    collect相當于toArray,toArray已經過時不推薦使用,collect將分布式的RDD返回為一個單機的scala Array數組。 在這個數組上運用scala的函數式操作。

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

    源碼:

    ?

    ?
  • /**

  • * Return an array that contains all of the elements in this RDD.

  • */

  • def collect(): Array[T] = {

  • val results = sc.runJob(this, (iter: Iterator[T]) => iter.toArray)

  • Array.concat(results: _*)

  • }

  • ?

    (2)collectAsMap

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

    圖中,左側方框代表RDD分區,右側方框代表單機數組。數據通過collectAsMap函數返回給Driver程序計算結果,結果以HashMap形式存儲。

    源碼:

    ?

    ?
  • /**

  • * Return the key-value pairs in this RDD to the master as a Map.

  • *

  • * Warning: this doesn't return a multimap (so if you have multiple values to the same key, only

  • * one value per key is preserved in the map returned)

  • */

  • def collectAsMap(): Map[K, V] = {

  • val data = self.collect()

  • val map = new mutable.HashMap[K, V]

  • map.sizeHint(data.length)

  • data.foreach { pair => map.put(pair._1, pair._2) }

  • map

  • }

  • ?

    (3)reduceByKeyLocally

    實現的是先reduce再collectAsMap的功能,先對RDD的整體進行reduce操作,然后再收集所有結果返回為一個HashMap。

    源碼:

    ?

    ?
  • /**

  • * Merge the values for each key using an associative reduce function, but return the results

  • * immediately to the master as a Map. This will also perform the merging locally on each mapper

  • * before sending results to a reducer, similarly to a "combiner" in MapReduce.

  • */

  • def reduceByKeyLocally(func: (V, V) => V): Map[K, V] = {

  • ?
  • if (keyClass.isArray) {

  • throw new SparkException("reduceByKeyLocally() does not support array keys")

  • }

  • ?
  • val reducePartition = (iter: Iterator[(K, V)]) => {

  • val map = new JHashMap[K, V]

  • iter.foreach { pair =>

  • val old = map.get(pair._1)

  • map.put(pair._1, if (old == null) pair._2 else func(old, pair._2))

  • }

  • Iterator(map)

  • } : Iterator[JHashMap[K, V]]

  • ?
  • val mergeMaps = (m1: JHashMap[K, V], m2: JHashMap[K, V]) => {

  • m2.foreach { pair =>

  • val old = m1.get(pair._1)

  • m1.put(pair._1, if (old == null) pair._2 else func(old, pair._2))

  • }

  • m1

  • } : JHashMap[K, V]

  • ?
  • self.mapPartitions(reducePartition).reduce(mergeMaps)

  • }

  • ?

    (4)lookup

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

    圖中,左側方框代表RDD分區,右側方框代表Seq,最后結果返回到Driver所在節點的應用中。

    源碼:

    ?

    ?
  • /**

  • * Return the list of values in the RDD for key `key`. This operation is done efficiently if the

  • * RDD has a known partitioner by only searching the partition that the key maps to.

  • */

  • def lookup(key: K): Seq[V] = {

  • self.partitioner match {

  • case Some(p) =>

  • val index = p.getPartition(key)

  • val process = (it: Iterator[(K, V)]) => {

  • val buf = new ArrayBuffer[V]

  • for (pair <- it if pair._1 == key) {

  • buf += pair._2

  • }

  • buf

  • } : Seq[V]

  • val res = self.context.runJob(self, process, Array(index), false)

  • res(0)

  • case None =>

  • self.filter(_._1 == key).map(_._2).collect()

  • }

  • }

  • ?

    (5)count

    count返回整個RDD的元素個數。?

    圖中,返回數據的個數為5。一個方塊代表一個RDD分區。

    源碼:

    ?

    ?
  • /**

  • * Return the number of elements in the RDD.

  • */

  • def count(): Long = sc.runJob(this, Utils.getIteratorSize _).sum

  • ?

    (6)top

    top可返回最大的k個元素。?
    相近函數說明:

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

    源碼:

    ?

    ?
  • /**

  • * Returns the top k (largest) elements from this RDD as defined by the specified

  • * implicit Ordering[T]. This does the opposite of [[takeOrdered]]. For example:

  • * {{{

  • * sc.parallelize(Seq(10, 4, 2, 12, 3)).top(1)

  • * // returns Array(12)

  • *

  • * sc.parallelize(Seq(2, 3, 4, 5, 6)).top(2)

  • * // returns Array(6, 5)

  • * }}}

  • *

  • * @param num k, the number of top elements to return

  • * @param ord the implicit ordering for T

  • * @return an array of top elements

  • */

  • def top(num: Int)(implicit ord: Ordering[T]): Array[T] = takeOrdered(num)(ord.reverse)

  • ?

    (7)reduce

    reduce函數相當于對RDD中的元素進行reduceLeft函數的操作。?
    reduceLeft先對兩個元素

    ?

    ?
  • /**

  • * Reduces the elements of this RDD using the specified commutative and

  • * associative binary operator.

  • */

  • def reduce(f: (T, T) => T): T = {

  • val cleanF = sc.clean(f)

  • val reducePartition: Iterator[T] => Option[T] = iter => {

  • if (iter.hasNext) {

  • Some(iter.reduceLeft(cleanF))

  • } else {

  • None

  • }

  • }

  • var jobResult: Option[T] = None

  • val mergeResult = (index: Int, taskResult: Option[T]) => {

  • if (taskResult.isDefined) {

  • jobResult = jobResult match {

  • case Some(value) => Some(f(value, taskResult.get))

  • case None => taskResult

  • }

  • }

  • }

  • sc.runJob(this, reducePartition, mergeResult)

  • // Get the final result out of our Option, or throw an exception if the RDD was empty

  • jobResult.getOrElse(throw new UnsupportedOperationException("empty collection"))

  • }

  • ?

    (8)fold

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

    圖中,通過用戶自定義函數進行fold運算,圖中的一個方框代表一個RDD分區。

    源碼:

    ?

    ?
  • /**

  • * Aggregate the elements of each partition, and then the results for all the partitions, using a

  • * given associative function and a neutral "zero value". The function op(t1, t2) is allowed to

  • * modify t1 and return it as its result value to avoid object allocation; however, it should not

  • * modify t2.

  • */

  • def fold(zeroValue: T)(op: (T, T) => T): T = {

  • // Clone the zero value since we will also be serializing it as part of tasks

  • var jobResult = Utils.clone(zeroValue, sc.env.closureSerializer.newInstance())

  • val cleanOp = sc.clean(op)

  • val foldPartition = (iter: Iterator[T]) => iter.fold(zeroValue)(cleanOp)

  • val mergeResult = (index: Int, taskResult: T) => jobResult = op(jobResult, taskResult)

  • sc.runJob(this, foldPartition, mergeResult)

  • jobResult

  • }

  • ?

    (9)aggregate

    aggregate先對每個分區的所有元素進行aggregate操作,再對分區的結果進行fold操作。?
    aggreagate與fold和reduce的不同之處在于,aggregate相當于采用歸并的方式進行數據聚集,這種聚集是并行化的。 而在fold和reduce函數的運算過程中,每個分區中需要進行串行處理,每個分區串行計算完結果,結果再按之前的方式進行聚集,并返回最終聚集結果。

    圖中,通過用戶自定義函數對RDD 進行aggregate的聚集操作,圖中的每個方框代表一個RDD分區。

    源碼:

    ?

    ?
  • /**

  • * Aggregate the elements of each partition, and then the results for all the partitions, using

  • * given combine functions and a neutral "zero value". This function can return a different result

  • * type, U, than the type of this RDD, T. Thus, we need one operation for merging a T into an U

  • * and one operation for merging two U's, as in scala.TraversableOnce. Both of these functions are

  • * allowed to modify and return their first argument instead of creating a new U to avoid memory

  • * allocation.

  • */

  • def aggregate[U: ClassTag](zeroValue: U)(seqOp: (U, T) => U, combOp: (U, U) => U): U = {

  • // Clone the zero value since we will also be serializing it as part of tasks

  • var jobResult = Utils.clone(zeroValue, sc.env.closureSerializer.newInstance())

  • val cleanSeqOp = sc.clean(seqOp)

  • val cleanCombOp = sc.clean(combOp)

  • val aggregatePartition = (it: Iterator[T]) => it.aggregate(zeroValue)(cleanSeqOp, cleanCombOp)

  • val mergeResult = (index: Int, taskResult: U) => jobResult = combOp(jobResult, taskResult)

  • sc.runJob(this, aggregatePartition, mergeResult)

  • jobResult

  • }

  • 原文鏈接:http://blog.csdn.net/jasonding1354

    總結

    以上是生活随笔為你收集整理的Spark RDD使用详解5--Action算子的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    国产精品99久久久久久人免费 | 在线免费视频一区 | 国产精品免费观看在线 | 国产美女黄网站免费 | 国产精品手机看片 | 日日操日日插 | 丝袜美腿在线播放 | 日韩欧美视频在线播放 | 日韩在线 一区二区 | 久久九九久久九九 | caobi视频 | 在线视频一二三 | 中文字幕在线免费97 | 亚洲精品视频免费在线 | 正在播放国产91 | 操操日 | 国产中文在线视频 | 日韩天堂在线观看 | 丁香花在线观看免费完整版视频 | 在线观看av不卡 | 99精品成人 | 狠狠色噜噜狠狠狠狠2022 | 精选久久| 操操操夜夜操 | 日本精品视频一区 | 午夜影视av | 日韩在线观看视频免费 | 亚洲一二三久久 | 最新午夜 | 欧美激情综合五月色丁香 | 成人av电影在线播放 | 日韩电影在线一区二区 | 日日干激情五月 | 日韩av一区二区三区 | 香蕉成人在线视频 | 麻花豆传媒mv在线观看网站 | 久久99热久久99精品 | 国产福利91精品一区 | 国产精品爽爽爽 | 少妇bbb | 欧美精品免费视频 | 91九色网站| 97在线观看免费高清完整版在线观看 | 97在线超碰 | 久久中文网 | 在线亚洲激情 | 成人午夜剧场在线观看 | 国产精品亚 | 国产自产高清不卡 | 久久精品看片 | 天天色综合久久 | 天天干人人干 | 国产精品96久久久久久吹潮 | 香蕉视频免费看 | 综合网五月天 | 国产视| 三级av网站| 丁香花在线观看免费完整版视频 | 国产精品99久久久久久武松影视 | 男女视频91 | 国产在线资源 | 麻豆免费精品视频 | 日韩视频1区 | 久久高清毛片 | 成人一级视频在线观看 | 在线免费观看羞羞视频 | 久久黄色网址 | 狠狠躁日日躁狂躁夜夜躁 | 99精品视频在线观看 | 天天爽天天做 | 亚洲成av人影片在线观看 | 精品高清美女精品国产区 | 天天躁日日躁狠狠躁 | 国产精品久久久久久久久久久久 | 国产3p视频| 日韩av三区 | 欧美一级淫片videoshd | 99久久久久 | 不卡日韩av | 精品国产1区2区3区 国产欧美精品在线观看 | 日韩久久久久久久 | 国产精品永久免费视频 | 成人免费视频免费观看 | 中文一区在线观看 | 国产一级二级在线观看 | 国产91九色视频 | 亚洲黄色在线播放 | 欧洲精品亚洲精品 | 中文字幕免费高清在线 | 国产高清在线观看av | a√天堂中文在线 | 91免费网 | 91自拍视频在线 | 大片网站久久 | 91精品秘密在线观看 | 国产一区免费在线 | 中文字幕日韩精品有码视频 | 久久任你操 | 精品一二 | 日韩成人黄色 | 天天色婷婷 | 日韩3区 | 国产成人a v电影 | 黄色小网站免费看 | 色狠狠久久av五月综合 | 91爱爱视频 | 黄色亚洲| 西西4444www大胆艺术 | 国产污视频在线观看 | 国产精品一区二区三区视频免费 | 九九热1 | 丁香在线视频 | 亚洲欧美视频一区二区三区 | 国内揄拍国内精品 | 国产又粗又猛又黄视频 | 人操人 | 中文字幕免费高清 | 麻豆传媒视频在线播放 | 在线观看国产中文字幕 | 九九99| 91.dizhi永久地址最新 | 深爱婷婷 | 欧美性天天 | 91精品国自产在线观看欧美 | av在线播放国产 | 久草视频首页 | 免费日韩一区二区三区 | 欧美另类亚洲 | 午夜精品久久久 | 亚洲国产日本 | 丁香婷婷综合激情 | 狠狠网 | 久久情爱 | 免费看一级黄色 | 国产在线欧美在线 | 在线免费观看视频你懂的 | 激情深爱| 999在线精品 | 欧美日韩性生活 | 久久99久久99精品免视看婷婷 | 免费日韩av片 | 在线视频观看亚洲 | 高清日韩一区二区 | 黄色视屏免费在线观看 | 亚州日韩中文字幕 | 色综合天天视频在线观看 | 蜜臀av夜夜澡人人爽人人桃色 | 中文字幕高清免费日韩视频在线 | 成人高清在线 | 亚洲国产精品久久 | 免费观看www视频 | 亚洲国产免费看 | 亚洲爽爽网 | 免费欧美 | 国产精品成 | 国产精品视频线看 | 国产精品视频地址 | 国产一区视频在线播放 | 久久久国产一区 | 999日韩 | 日韩免费成人 | 亚洲欧美视屏 | 91成人天堂久久成人 | 91在线看视频免费 | 国产精品久久电影网 | 亚洲人成免费网站 | 草久久久 | 三级在线国产 | 欧美精品视 | 最近中文字幕高清字幕在线视频 | 一区二区三区污 | 精品久久久久久综合 | 婷婷色五 | 精品一区二区在线播放 | 国产91在线看 | 久精品视频在线观看 | www.综合网.com| 日韩在线观看第一页 | 国产精品成人免费一区久久羞羞 | 国产麻豆果冻传媒在线观看 | 久久久99精品免费观看 | 亚洲国产网站 | 国产成人av网址 | 日韩精品久久一区二区三区 | 又粗又长又大又爽又黄少妇毛片 | 久久99精品久久久久久 | 国产精品久免费的黄网站 | www激情网 | 日韩网站免费观看 | 在线国产一区 | 在线观看国产一区二区 | 在线免费观看视频你懂的 | 五月天久久综合网 | 免费男女羞羞的视频网站中文字幕 | 天天操导航 | 男女啪啪视屏 | 国产三级精品三级在线观看 | 免费毛片aaaaaa | 五月婷婷中文字幕 | 日韩二区三区在线 | 69xx视频| 涩涩网站在线观看 | 亚洲视频网站在线观看 | 国产一级淫片在线观看 | 在线a人v观看视频 | 精品国产伦一区二区三区免费 | 午夜精品福利在线 | 91麻豆精品 | 天天爽综合网 | 波多野结衣精品 | 999久久国精品免费观看网站 | 九九热视频在线播放 | 国产青草视频在线观看 | 91久久一区二区 | av在线激情 | 国产96av | 在线黄色毛片 | 中文字幕乱码日本亚洲一区二区 | 五月婷婷色 | 免费v片 | 久久国内精品视频 | 国产手机精品视频 | 9992tv成人免费看片 | 国产一区二区不卡在线 | 久久综合之合合综合久久 | 亚洲一二区视频 | 国产香蕉97碰碰碰视频在线观看 | 国产精品99蜜臀久久不卡二区 | 久久国产精品精品国产色婷婷 | 丁香电影小说免费视频观看 | 久久av中文字幕片 | 三级av在线免费观看 | 久久99这里只有精品 | 国产麻豆成人传媒免费观看 | 久草精品电影 | 国产经典三级 | 超碰人人乐 | 成人久久免费 | 免费人成网ww44kk44 | 日韩在线视 | 一级黄色a视频 | japanesexxxxfreehd乱熟 | 在线观看国产中文字幕 | 91精品国产福利在线观看 | 成人av在线网址 | 在线观看av片 | 91最新中文字幕 | 日女人电影 | av噜噜噜在线播放 | 精品亚洲成人 | 亚洲狠狠操| 亚洲电影图片小说 | 久久久久网站 | 日韩特级黄色片 | 日本乱码在线 | 欧美日韩三级在线观看 | 亚洲理论电影网 | 婷婷精品国产欧美精品亚洲人人爽 | 欧美天天干 | 免费男女羞羞的视频网站中文字幕 | 在线看一区二区 | 成人作爱视频 | 在线影院中文字幕 | 91丨九色丨国产在线 | 成人黄色av免费在线观看 | 亚洲免费小视频 | 久久伦理电影网 | 在线观看一区二区精品 | 啪啪资源 | 天天拍天天干 | 国产精品久久久久久一区二区 | 久久午夜色播影院免费高清 | 国产中文字幕视频在线观看 | 亚洲另类视频在线观看 | 菠萝菠萝蜜在线播放 | 亚洲日韩欧美一区二区在线 | 97精品国自产拍在线观看 | 在线观看一级片 | 亚洲国产精品久久久久婷婷884 | 伊人电影在线观看 | av一本久道久久波多野结衣 | 国产精品一区二区精品视频免费看 | av网址在线播放 | 中文字幕日韩免费视频 | 久久国产a | 中文字幕大全 | 国产精品99久久久久久宅男 | 天天搞天天干天天色 | 中文字幕国产 | 欧美动漫一区二区三区 | 午夜精品一区二区三区在线 | 91av免费观看 | 亚洲首页 | 91九色视频 | 美女网站色在线观看 | 久草视频在线播放 | 国产欧美日韩一区 | 999国产精品视频 | 国产综合香蕉五月婷在线 | 91在线精品观看 | 91精品国产一区 | 久久视频在线观看中文字幕 | 久久成人在线视频 | 成年人黄色免费网站 | 成人免费视频播放 | 成年人免费观看在线视频 | 国产成人精品亚洲日本在线观看 | 亚洲va欧美va国产va黑人 | 国产成人a亚洲精品v | 91视频88av | 四虎影视8848aamm | 国产精品久久久久久久久久99 | 国产精品久久久久久久久免费看 | 美女国内精品自产拍在线播放 | 天天综合网在线 | 国产又粗又硬又长又爽的视频 | 久久亚洲精品国产亚洲老地址 | 正在播放 久久 | 就要干b | 色视频一区 | 黄色综合 | 久草a在线 | 久久久久久网站 | 国产欧美在线一区二区三区 | 亚洲91网站 | 国产美女视频免费 | 在线亚洲欧美日韩 | 美女视频黄免费的久久 | 激情电影在线观看 | 国产无遮挡又黄又爽馒头漫画 | 日韩免费一级a毛片在线播放一级 | av在线亚洲天堂 | 婷婷色影院 | 日韩黄色中文字幕 | 久草在线视频新 | 日日操夜 | 亚洲砖区区免费 | 天天射天天干天天爽 | 久久99精品久久久久久久久久久久 | 国产蜜臀av| 免费视频一区二区 | 毛片99| 日日干干 | 国产精品欧美久久久久天天影视 | 亚洲午夜电影网 | 久久国精品 | 在线观看国产91 | 欧美久久久久久久久久 | 黄色电影网站在线观看 | 在线免费黄色av | 国产麻豆果冻传媒在线观看 | 99久久国产免费免费 | 九九交易行官网 | 韩国av电影网 | 丝袜美女视频网站 | a色视频| 99热在| 色狠狠婷婷 | 91在线播放视频 | 日韩午夜剧场 | 国产精品va | www.天天色 | 亚洲精品视频网站在线观看 | 免费视频成人 | 久久综合中文色婷婷 | 亚洲国产精品女人久久久 | av电影久久 | 国产你懂的在线 | 亚洲欧美成人在线 | 91黄色在线看 | 狠狠操狠狠干天天操 | 亚洲欧洲日韩在线观看 | 99国内精品 | 香蕉视频一级 | 欧美美女视频在线观看 | 午夜视频一区二区三区 | 国产小视频在线观看免费 | 成人一区二区三区在线观看 | 亚洲永久精品一区 | 国产精品九九热 | 射射射av| 日韩精品久久久 | 片网站 | 国产精彩视频 | 992tv在线观看 | 中文字幕免费高清av | 色网站在线免费观看 | 永久免费精品视频网站 | 99r在线视频 | 97狠狠操| 99精品久久久久 | 久久久福利影院 | 欧美另类sm图片 | 免费视频你懂得 | 91亚洲精品久久久蜜桃网站 | 国产伦精品一区二区三区四区视频 | 四川妇女搡bbbb搡bbbb搡 | 99 久久久久| 国产精品视频999 | av免费片 | 91mv.cool在线观看 | 自拍超碰在线 | 日韩久久久久久久 | 精品日韩在线一区 | 国产精品久久久久久久久婷婷 | 久久深夜福利免费观看 | 黄色特级一级片 | 俺要去色综合狠狠 | 最新色视频| 国产精品一区二区免费视频 | 91在线你懂的 | 国产成人av综合色 | 欧美在线视频第一页 | 最近日本字幕mv免费观看在线 | 免费网站看v片在线a | 久草网视频在线观看 | 国产99区 | 日本精品久久久久中文字幕 | 18性欧美xxxⅹ性满足 | 欧美99精品| 超碰资源在线 | 国产亚洲精品久久久久久 | 91色吧| 国产精品初高中精品久久 | 超碰精品在线观看 | 91在线观看视频 | 国产色视频网站 | 欧洲亚洲国产视频 | 天天躁日日躁狠狠躁av中文 | 日韩精品不卡 | 国产精品久久久久久久久久久免费 | 99精品视频在线观看免费 | 久久精国产 | 在线三级中文 | 日韩视频免费在线 | 成人综合婷婷国产精品久久免费 | 日韩高清av在线 | 午夜久久影院 | 成人av影视观看 | 天天综合网在线观看 | 欧美日韩xxxxx | 婷婷av网 | 亚洲 欧美变态 另类 综合 | 91人人干 | 国产午夜av | 国产精品免费久久久久 | 国产成人精品久久亚洲高清不卡 | 中文字幕日韩有码 | 亚洲欧美综合 | 亚洲经典中文字幕 | 日韩精品免费在线观看视频 | 午夜国产一区二区三区四区 | 亚洲精品影视 | 日韩成年视频 | 国产一区二区不卡视频 | 亚洲专区欧美 | 国产亚洲观看 | 日韩一区视频在线 | 黄色福利视频网站 | 伊人激情综合 | 激情五月婷婷丁香 | 国产精品视频不卡 | 欧美专区国产专区 | 在线观看一级 | 在线观看播放av | 久久丝袜视频 | 国产在线精品国自产拍影院 | 国产精品激情偷乱一区二区∴ | 色爱区综合激月婷婷 | 久久人操 | 中文字幕电影高清在线观看 | 国产一区视频在线 | 亚洲一区视频在线播放 | 国精产品999国精产品岳 | 久久久影院官网 | 激情视频国产 | 97色综合| 在线免费av观看 | 国产成人精品一区二区三区福利 | 午夜av不卡| 色综合五月天 | 六月天色婷婷 | 国内精品久久久久久久久 | 日日干天天插 | 国产精品免费视频网站 | 日韩精品一区电影 | 中文字幕高清免费日韩视频在线 | www.com久久久 | 欧美激情第一页xxx 午夜性福利 | 一区二区三区精品在线视频 | 韩国三级一区 | 五月天av在线 | 丁香激情网 | 国产精品免费观看久久 | 91九色视频在线观看 | 欧美一区二区在线看 | 免费看黄20分钟 | 亚洲黄色小说网址 | av免费看网站 | a视频在线| 啪啪动态视频 | 中文在线a在线 | 蜜臀av在线一区二区三区 | 在线а√天堂中文官网 | 国产一区二区在线视频观看 | 91精品亚洲影视在线观看 | 久久黄色成人 | 操高跟美女 | 免费精品久久久 | 国产精品久久久久影院 | 欧美激情第28页 | 久久短视频 | 人人操日日干 | 中文字幕亚洲字幕 | 精品一区精品二区高清 | av网站地址| 中文字幕在线视频一区二区 | 国产精品久久久99 | 在线播放 日韩专区 | 毛片网站免费 | 久久天天躁夜夜躁狠狠85麻豆 | 国产精品久久久久久久久久妇女 | 久久视频这里只有精品 | 一本一本久久a久久精品综合妖精 | 麻豆精品传媒视频 | 欧美激情综合五月色丁香 | 成年人在线观看免费视频 | 午夜视频在线观看一区二区三区 | 91综合色| 国产精品久久婷婷六月丁香 | 日韩免费不卡av | 91九色porny蝌蚪视频 | 国产精品视频全国免费观看 | 免费观看十分钟 | 久久久久国产成人免费精品免费 | 色91在线视频| 最新日韩视频在线观看 | 亚洲精品人人 | 992tv又爽又黄的免费视频 | 狠狠成人 | 日韩在线视频线视频免费网站 | 日韩视频图片 | 亚洲成人精品 | 免费观看mv大片高清 | 一级成人免费视频 | 久久综合久久88 | 最近高清中文字幕 | 色婷婷狠狠五月综合天色拍 | 欧美二区视频 | 青春草视频在线播放 | av片无限看| a黄色大片 | 国产在线美女 | 1000部18岁以下禁看视频 | 91久久精品一区二区三区 | 五月天亚洲激情 | 在线观看电影av | 日韩在线二区 | 国产精品6999成人免费视频 | 免费观看性生交 | 亚洲综合狠狠干 | 天天操天天拍 | 亚洲 综合 激情 | 日韩大片在线免费观看 | 亚洲国产一区二区精品专区 | 日韩精品一区二区三区中文字幕 | 丁香五婷| 成人在线观看免费视频 | 日韩免费一区二区 | 日韩精品免费在线视频 | 夜夜狠狠| 国产a级片免费观看 | 国产一区二区在线免费播放 | 国产一区成人 | 91精品第一页 | a级片网站| 免费在线观看国产黄 | 午夜体验区 | 国产xxxxx在线观看 | 免费色黄 | 色狠狠综合 | 丁香久久激情 | 在线观看91久久久久久 | 天天色天天干天天 | 免费观看一级一片 | 日韩成人免费观看 | 丁香五香天综合情 | 人人插人人干 | 91看片淫黄大片在线播放 | 999久久| 久久尤物电影视频在线观看 | 免费三级骚 | 国产精品理论片 | 欧美另类tv| 色无五月| 91日韩在线视频 | 在线国产一区二区三区 | 久久激情视频免费观看 | 91成熟丰满女人少妇 | 欧美激情视频在线观看免费 | 嫩模bbw搡bbbb搡bbbb | 免费aa大片| 五月婷在线播放 | 91精品视频免费在线观看 | 午夜视频在线观看一区 | 五月婷婷在线观看视频 | 日韩av免费在线电影 | 日本三级香港三级人妇99 | 激情丁香| 狠狠干,狠狠操 | 国产一区二区在线免费播放 | 国产精品久久久久久超碰 | 日韩中文字幕在线不卡 | 国产手机视频在线 | 91精品伦理 | 精品一区91 | 日韩精品久久久久久中文字幕8 | 中文字幕 二区 | 99精品视频在线看 | 在线看成人片 | 日日日日日 | 开心激情五月婷婷 | 国产九九热| 国产aa精品 | 欧美日韩免费一区二区三区 | 亚洲黄色免费电影 | 中文一区在线观看 | 超碰久热 | 国产精品视频地址 | 久久精品国产v日韩v亚洲 | 成人影片在线免费观看 | 亚洲三级黄色 | 欧美a级在线免费观看 | 99精品免费久久久久久久久 | 在线视频观看你懂的 | 国产视频手机在线 | 欧美激情视频一区二区三区免费 | 狠狠色丁香久久综合网 | 久草在线免费电影 | 国产手机视频在线播放 | 久久国产精品免费视频 | 天堂av色婷婷一区二区三区 | av中文字幕在线观看网站 | 久久成人亚洲欧美电影 | 亚洲高清视频一区二区三区 | 日韩免费小视频 | 在线有码中文字幕 | 国产成人一区二区在线观看 | 九九久久精品视频 | 欧美在线观看视频免费 | 久久九九免费视频 | 日韩激情久久 | 久久精品欧美一区 | 97超碰人人澡人人 | 国产私拍在线 | 日韩久久久久久久 | av一本久道久久波多野结衣 | 国内少妇自拍视频一区 | 91专区在线观看 | 精品视频在线播放 | 精品uu| 在线播放 日韩专区 | 亚洲精品玖玖玖av在线看 | 日韩大陆欧美高清视频区 | 国产成人在线网站 | 久久免费成人网 | 天天久久夜夜 | 就要干b | 久久兔费看a级 | 999视频在线播放 | 1024在线看片 | 免费福利片 | 女人18毛片a级毛片一区二区 | 最近中文字幕mv | 久久人人爽爽人人爽人人片av | 日日干日日色 | 久久精品国产亚洲精品 | 日韩中文字幕一区 | 中文字幕91视频 | 欧美日韩不卡一区二区三区 | 麻豆免费视频网站 | 国产精品黑丝在线观看 | 精品免费 | 国产一区在线视频 | 日韩高清观看 | 免费在线视频一区二区 | 久久的色| 日本丶国产丶欧美色综合 | 免费av片在线 | 中文字幕免费观看全部电影 | 国产色婷婷精品综合在线手机播放 | 草久在线观看视频 | 欧美在线1区 | 国产免费久久精品 | 免费a视频在线观看 | 国产中文字幕视频在线观看 | 在线日韩av | 日韩精品最新在线观看 | 国产小视频在线观看 | 九九九视频精品 | 狠狠狠狠狠狠 | 麻豆视频网址 | 欧美日韩精品免费观看视频 | 天天综合导航 | a天堂一码二码专区 | 一级片免费观看视频 | 久久香蕉国产 | 伊人热| 天天色综合三 | 亚洲成人午夜在线 | 午夜在线看片 | 99 精品 在线 | 亚洲国产精品va在线看黑人动漫 | 欧美激情另类 | 美女网站在线 | 国产精品综合久久久 | 欧美日韩国产成人 | 日韩视频免费看 | 国产一区二区在线免费 | 国内精品久久久久影院日本资源 | 97视频精品 | 日韩av在线一区二区 | 日韩在线视频免费看 | 美女露久久 | 久久九九网站 | 国产午夜精品一区二区三区嫩草 | 一级电影免费在线观看 | 在线观看亚洲精品视频 | 狠狠操综合网 | 日韩乱理 | 激情久久综合 | 久久在线视频精品 | 伊人资源站 | 九九综合久久 | 成人av免费在线看 | 激情综合色播五月 | www.天天色| av大全免费在线观看 | 成人h视频在线 | 久草在线视频免赞 | 亚洲精品美女久久久 | 久久国产美女 | 三日本三级少妇三级99 | 欧洲一区二区在线观看 | 日韩电影在线观看一区二区三区 | 在线观看av中文字幕 | 久久久久久国产精品999 | 日本一区二区三区免费看 | 国产精品videoxxxx | 国产又粗又硬又爽的视频 | 999久久久免费视频 午夜国产在线观看 | 亚洲国产高清在线观看视频 | 麻豆久久久久久久 | 四虎8848免费高清在线观看 | 久久精品一二三 | 97国产 | 国产精品原创 | 91一区啪爱嗯打偷拍欧美 | 91九色视频观看 | 深爱激情久久 | 波多野结衣电影一区二区 | 五月综合婷 | 日本一区二区三区免费看 | 免费麻豆 | 亚洲免费永久精品国产 | 日韩欧美在线观看一区二区三区 | 国产成人1区| 日本一区二区三区免费观看 | 亚洲 欧美 精品 | 日韩a级黄色片 | 亚洲国产精品成人av | av在线免费观看不卡 | 久久99精品久久久久蜜臀 | 亚洲午夜av电影 | 97超碰精品| 亚洲经典视频 | 成年人视频在线观看免费 | 国产无遮挡又黄又爽在线观看 | 五月婷婷欧美 | 免费视频久久久久久久 | 欧美激情va永久在线播放 | 午夜视频导航 | 97av在线| 中文免费 | 国产小视频免费在线网址 | 国产网红在线观看 | 三级黄色网络 | 99国产精品免费网站 | 永久免费的av电影 | 日韩精品专区在线影院重磅 | 91精品国产99久久久久久久 | 在线观看视频 | 国产精品资源在线观看 | 国产福利一区二区三区视频 | 久久精品影片 | 国产精品久久久久影院日本 | av电影不卡在线 | 在线观看国产www | 久久久国产成人 | 最新中文字幕在线播放 | 国产伦理久久精品久久久久_ | 亚洲观看黄色网 | 欧美一区三区四区 | 91av资源在线 | 亚洲无吗视频在线 | 亚洲精品国产综合99久久夜夜嗨 | 亚洲免费精彩视频 | 国产一级免费观看 | 久久综合五月 | 久久精品高清视频 | 97精品国产一二三产区 | 天天爽天天摸 | www.com.黄| 正在播放日韩 | 高清免费av在线 | 欧美在线不卡一区 | 欧美激情视频一区二区三区免费 | 粉嫩高清一区二区三区 | 午夜国产福利在线 | 日韩一区二区三区免费电影 | 亚洲激精日韩激精欧美精品 | 日韩久久影院 | 天天射天天干天天操 | 久久看片网站 | 69精品在线观看 | 国精产品999国精产品视频 | 九草视频在线观看 | 中文字幕av在线播放 | 91精品国产一区 | 日本女人逼 | 成人性生爱a∨ | 99久久久国产精品免费99 | 色婷婷丁香 | 国产成人精品一区二三区 | 亚洲专区视频在线观看 | 亚洲一本视频 | 日本99热 | 又黄又爽免费视频 | 久久九九影视网 | 日韩免费一级a毛片在线播放一级 | 欧美视频xxx | 国产中文字幕一区二区 | 91九色在线 | 天天做天天爱天天爽综合网 | 97电影网站 | 欧美日韩一区二区免费在线观看 | www.久久99| 五月婷婷久草 | 视频二区在线 | 九九在线精品视频 | 日韩久久久久久久久久久久 | 亚洲最新av | 91免费观看网站 | 91资源在线免费观看 | 欧美精品久久久久久久久老牛影院 | 欧美男同网站 | 国产精品久久久久久久久久不蜜月 | 中文字幕在线观看视频一区二区三区 | 久久综合色婷婷 | 精品久操 | 久久久高清一区二区三区 | 国产一级黄色电影 | 日韩理论片中文字幕 | 亚洲专区欧美 | av免费片 | av中文字幕在线观看网站 | 天天干天天干天天射 | 夜夜看av| 中文字幕韩在线第一页 | 欧美一二三视频 | 蜜臀一区二区三区精品免费视频 | 日韩精品一区不卡 | 久久人人97超碰国产公开结果 | 日韩av电影网站在线观看 | 在线91播放 | 高清精品在线 | 在线观看中文字幕亚洲 | 国产1级视频 | 美女视频永久黄网站免费观看国产 | 丁香激情视频 | 国产美女视频免费观看的网站 | 天天干,夜夜爽 | 免费美女久久99 | 色婷婷国产精品 | 天天干天天操av | 亚洲一级二级 | 精品免费观看 | 成人免费视频免费观看 | 在线a人片免费观看视频 | 天天干.com | 99热最新精品 | 麻豆视频www | 九九热在线精品 | 国产亚洲精品久久 | 欧美激情综合五月色丁香 | 色婷婷综合在线 | 亚洲精品视频大全 | 国产精品成人在线 | 亚洲成a人片77777潘金莲 | 国产精品私拍 | 精品主播网红福利资源观看 | 99色免费视频 | 伊人五月天综合 | www.av小说| 蜜臀久久99精品久久久久久网站 | 免费观看一区二区三区视频 | 综合久久网| 在线看成人 | 国产精品一区二区果冻传媒 | 国产在线观看99 | 国产最新在线观看 | 91在线91 | 久久高清视频免费 | www久久九| www.一区二区三区 | 久久伊人八月婷婷综合激情 | 91视频啊啊啊 | а天堂中文最新一区二区三区 | 亚洲美女久久 | 久久国产精品99国产 | 久草免费在线观看视频 | 国产小视频在线 | 91精品久久久久久综合乱菊 | 国产精品久久久久久久久久妇女 | 精品在线观看国产 | 国产啊v在线| 国产男女爽爽爽免费视频 | 久久tv| 亚洲波多野结衣 | 啪啪激情网 | 黄色一区二区在线观看 | www激情久久 | 国产精品乱码久久久 | 91免费高清 | 在线视频亚洲 | 久久看视频 | 亚洲aⅴ乱码精品成人区 | 久久人人射 | 国产在线不卡精品 | 亚洲日韩欧美一区二区在线 | 国产小视频91 | 亚洲视频播放 | 五月天久久久久久 | 国产九九在线 | 六月丁香久久 | 91探花国产综合在线精品 | 色悠悠久久综合 | 网址你懂的在线观看 | 日精品 | 成人一区二区在线 | 黄色免费看片网站 | 欧美一级久久 | 成人 国产 在线 | 欧洲亚洲激情 | 国产91精品看黄网站 | av高清网站在线观看 | 日韩精品在线看 | 欧美成人理伦片 | 亚洲播播 | 99欧美| 国产视频欧美视频 | 日韩免费三区 | 久久综合网色—综合色88 | 狠狠色丁香久久婷婷综合五月 | 亚洲精品玖玖玖av在线看 | 国产精品v欧美精品v日韩 | 一区二区三区av在线 | 日韩欧美在线观看 | 欧美日韩精品在线观看视频 | 国产手机免费视频 | 狠狠色噜噜狠狠狠合久 | 色噜噜日韩精品欧美一区二区 | 日韩欧美xx | 黄网站色 | 日韩影片在线观看 | 亚洲精品国产精品乱码不99热 | 九九爱免费视频在线观看 | 久久视精品| 午夜精品久久久久久久99无限制 | 97**国产露脸精品国产 | 99色在线观看 | av在线播放亚洲 | 国产一区二区久久久久 | 天天爽天天爽天天爽 | 欧美精品乱码久久久久久 | 日韩电影在线观看一区 | 免费观看一区二区 | 五月综合 | 中文字幕电影高清在线观看 | 日韩美女久久 | 日本性久久 | 色婷婷国产精品 | 日韩一级电影在线观看 | 国产在线观看中文字幕 | 色综合天天视频在线观看 | 97色国产| 国产成人精品一区二区在线 | 在线激情小视频 |