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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Mapreduce执行过程分析(基于Hadoop2.4)——(一)

發(fā)布時間:2023/12/10 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Mapreduce执行过程分析(基于Hadoop2.4)——(一) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1 概述

該瞅瞅MapReduce的內(nèi)部運(yùn)行原理了,以前只知道個皮毛,再不搞搞,不然怎么死的都不曉得。下文會以2.4版本中的WordCount這個經(jīng)典例子作為分析的切入點(diǎn),一步步來看里面到底是個什么情況。

2 為什么要使用MapReduce

Map/Reduce,是一種模式,適合解決并行計算的問題,比如TopN、貝葉斯分類等。注意,是并行計算,而非迭代計算,像涉及到層次聚類的問題就不太適合了。

從名字可以看出,這種模式有兩個步驟,Map和Reduce。Map即數(shù)據(jù)的映射,用于把一組鍵值對映射成另一組新的鍵值對,而Reduce這個東東,以Map階段的輸出結(jié)果作為輸入,對數(shù)據(jù)做化簡、合并等操作。

而MapReduce是Hadoop生態(tài)系統(tǒng)中基于底層HDFS的一個計算框架,它的上層又可以是Hive、Pig等數(shù)據(jù)倉庫框架,也可以是Mahout這樣的數(shù)據(jù)挖掘工具。由于MapReduce依賴于HDFS,其運(yùn)算過程中的數(shù)據(jù)等會保存到HDFS上,把對數(shù)據(jù)集的計算分發(fā)給各個節(jié)點(diǎn),并將結(jié)果進(jìn)行匯總,再加上各種狀態(tài)匯報、心跳匯報等,其只適合做離線計算。和實(shí)時計算框架Storm、Spark等相比,速度上沒有優(yōu)勢。舊的Hadoop生態(tài)幾乎是以MapReduce為核心的,但是慢慢的發(fā)展,其擴(kuò)展性差、資源利用率低、可靠性等問題都越來越讓人覺得不爽,于是才產(chǎn)生了Yarn這個新的東東,并且二代版的Hadoop生態(tài)都是以Yarn為核心。Storm、Spark等都可以基于Yarn使用。

3 怎么運(yùn)行MapReduce

明白了哪些地方可以使用這個牛叉的MapReduce框架,那該怎么用呢?Hadoop的MapReduce源碼給我們提供了范例,在其hadoop-mapreduce-examples子工程中包含了MapReduce的Java版例子。在寫完類似的代碼后,打包成jar,在HDFS的客戶端運(yùn)行:

bin/hadoop jar mapreduce_examples.jar mainClass args

即可。當(dāng)然,也可以在IDE(如Eclipse)中,進(jìn)行遠(yuǎn)程運(yùn)行、調(diào)試程序。

至于,HadoopStreaming方式,網(wǎng)上有很多。我們這里只討論Java的實(shí)現(xiàn)。

4 如何編寫MapReduce程序

??? 如前文所說,MapReduce中有Map和Reduce,在實(shí)現(xiàn)MapReduce的過程中,主要分為這兩個階段,分別以兩類函數(shù)進(jìn)行展現(xiàn),一個是map函數(shù),一個是reduce函數(shù)。map函數(shù)的參數(shù)是一個<key,value>鍵值對,其輸出結(jié)果也是鍵值對,reduce函數(shù)以map的輸出作為輸入進(jìn)行處理。

4.1 代碼構(gòu)成

??? 實(shí)際的代碼中,需要三個元素,分別是Map、Reduce、運(yùn)行任務(wù)的代碼。這里的Map類是繼承了org.apache.hadoop.mapreduce.Mapper,并實(shí)現(xiàn)其中的map方法;而Reduce類是繼承了org.apache.hadoop.mapreduce.Reducer,實(shí)現(xiàn)其中的reduce方法。至于運(yùn)行任務(wù)的代碼,就是我們程序的入口。

??? 下面是Hadoop提供的WordCount源碼。

1 /** 2 * Licensed to the Apache Software Foundation (ASF) under one 3 * or more contributor license agreements. See the NOTICE file 4 * distributed with this work for additional information 5 * regarding copyright ownership. The ASF licenses this file 6 * to you under the Apache License, Version 2.0 (the 7 * "License"); you may not use this file except in compliance 8 * with the License. You may obtain a copy of the License at 9 * 10 * http://www.apache.org/licenses/LICENSE-2.0 11 * 12 * Unless required by applicable law or agreed to in writing, software 13 * distributed under the License is distributed on an "AS IS" BASIS, 14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15 * See the License for the specific language governing permissions and 16 * limitations under the License. 17 */ 18 package org.apache.hadoop.examples; 19 20 import java.io.IOException; 21 import java.util.StringTokenizer; 22 23 import org.apache.hadoop.conf.Configuration; 24 import org.apache.hadoop.fs.Path; 25 import org.apache.hadoop.io.IntWritable; 26 import org.apache.hadoop.io.Text; 27 import org.apache.hadoop.mapreduce.Job; 28 import org.apache.hadoop.mapreduce.Mapper; 29 import org.apache.hadoop.mapreduce.Reducer; 30 import org.apache.hadoop.mapreduce.lib.input.FileInputFormat; 31 import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat; 32 import org.apache.hadoop.util.GenericOptionsParser; 33 34 public class WordCount { 35 36 public static class TokenizerMapper 37 extends Mapper<Object, Text, Text, IntWritable>{ 38 39 private final static IntWritable one = new IntWritable(1); 40 private Text word = new Text(); 41 42 public void map(Object key, Text value, Context context 43 ) throws IOException, InterruptedException { 44 StringTokenizer itr = new StringTokenizer(value.toString()); 45 while (itr.hasMoreTokens()) { 46 word.set(itr.nextToken()); 47 context.write(word, one); 48 } 49 } 50 } 51 52 public static class IntSumReducer 53 extends Reducer<Text,IntWritable,Text,IntWritable> { 54 private IntWritable result = new IntWritable(); 55 56 public void reduce(Text key, Iterable<IntWritable> values, 57 Context context 58 ) throws IOException, InterruptedException { 59 int sum = 0; 60 for (IntWritable val : values) { 61 sum += val.get(); 62 } 63 result.set(sum); 64 context.write(key, result); 65 } 66 } 67 68 public static void main(String[] args) throws Exception { 69 Configuration conf = new Configuration(); 70 String[] otherArgs = new GenericOptionsParser(conf, args).getRemainingArgs(); 71 if (otherArgs.length != 2) { 72 System.err.println("Usage: wordcount <in> <out>"); 73 System.exit(2); 74 } 75 Job job = new Job(conf, "word count"); 76 job.setJarByClass(WordCount.class); 77 job.setMapperClass(TokenizerMapper.class); 78 job.setCombinerClass(IntSumReducer.class); 79 job.setReducerClass(IntSumReducer.class); 80 job.setOutputKeyClass(Text.class); 81 job.setOutputValueClass(IntWritable.class); 82 FileInputFormat.addInputPath(job, new Path(otherArgs[0])); 83 FileOutputFormat.setOutputPath(job, new Path(otherArgs[1])); 84 System.exit(job.waitForCompletion(true) ? 0 : 1); 85 } 86 } View Code

?

4.2 入口類

4.2.1 參數(shù)獲取

首先定義配置文件類Configuration,此類是Hadoop各個模塊的公共使用類,用于加載類路徑下的各種配置文件,讀寫其中的配置選項(xiàng)。

??? 第二步中,用到了GenericOptionsParser類,其目的是將命令行中參數(shù)自動設(shè)置到變量conf中。

??? GenericOptionsParser的構(gòu)造方法進(jìn)去之后,會進(jìn)行到parseGeneralOptions,對傳入的參數(shù)進(jìn)行解析:

1 private void parseGeneralOptions(Options opts, Configuration conf, 2 3 String[] args) throws IOException { 4 5 opts = buildGeneralOptions(opts); 6 7 CommandLineParser parser = new GnuParser(); 8 9 try { 10 11 commandLine = parser.parse(opts, preProcessForWindows(args), true); 12 13 processGeneralOptions(conf, commandLine); 14 15 } catch(ParseException e) { 16 17 LOG.warn("options parsing failed: "+e.getMessage()); 18 19 20 21 HelpFormatter formatter = new HelpFormatter(); 22 23 formatter.printHelp("general options are: ", opts); 24 25 } 26 27 }

?

? ?而getRemainingArgs方法會獲得傳入的參數(shù),接著在main方法中會進(jìn)行判斷參數(shù)的個數(shù),由于此處是WordCount計算,只需要傳入文件的輸入路徑和輸出路徑即可,因此參數(shù)的個數(shù)為2,否則將退出:

1 if (otherArgs.length != 2) { 2 3 System.err.println("Usage: wordcount <in> <out>"); 4 5 System.exit(2); 6 7 }

?

如果在代碼運(yùn)行的時候傳入其他的參數(shù),比如指定reduce的個數(shù),可以根據(jù)GenericOptionsParser的命令行格式這么寫:

bin/hadoop jar MyJob.jar com.xxx.MyJobDriver -Dmapred.reduce.tasks=5

其規(guī)則是-D加MapReduce的配置選項(xiàng),當(dāng)然還支持-fs等其他參數(shù)傳入。當(dāng)然,默認(rèn)情況下Reduce的數(shù)目為1,Map的數(shù)目也為1

4.2.2 Job定義

?? 定義Job對象,其構(gòu)造方法為:

1 public Job(Configuration conf, String jobName) throws IOException { 2 3 this(conf); 4 5 setJobName(jobName); 6 7 }

?

可見,傳入的"word count"就是Job的名字。而conf被傳遞給了JobConf進(jìn)行環(huán)境變量的獲取:

1 public JobConf(Configuration conf) { 2 3 super(conf); 6 7 if (conf instanceof JobConf) { 8 9 JobConf that = (JobConf)conf; 10 11 credentials = that.credentials; 12 13 } 14 checkAndWarnDeprecation(); 19 }

?

??? Job已經(jīng)實(shí)例化了,下面就得給這個Job加點(diǎn)佐料才能讓它按照我們的要求運(yùn)行。于是依次給Job添加啟動Jar包、設(shè)置Mapper類、設(shè)置合并類、設(shè)置Reducer類、設(shè)置輸出鍵類型、設(shè)置輸出值的類型。

??? 這里有必要說下設(shè)置Jar包的這個方法setJarByClass:

1 public void setJarByClass(Class<?> cls) { 2 3 ensureState(JobState.DEFINE); 4 5 conf.setJarByClass(cls); 6 7 }

?

它會首先判斷當(dāng)前Job的狀態(tài)是否是運(yùn)行中,接著通過class找到其所屬的jar文件,將jar路徑賦值給mapreduce.job.jar屬性。至于尋找jar文件的方法,則是通過classloader獲取類路徑下的資源文件,進(jìn)行循環(huán)遍歷。具體實(shí)現(xiàn)見ClassUtil類中的findContainingJar方法。

??? 搞完了上面的東西,緊接著就會給mapreduce.input.fileinputformat.inputdir參數(shù)賦值,這是Job的輸入路徑,還有mapreduce.input.fileinputformat.inputdir,這是Job的輸出路徑。具體的位置,就是我們前面main中傳入的Args。

4.2.3 Job提交

??? 萬事俱備,那就運(yùn)行吧。

??? 這里調(diào)用的方法如下:

1 public boolean waitForCompletion(boolean verbose 2 3 ) throws IOException, InterruptedException, 4 5 ClassNotFoundException { 6 7 if (state == JobState.DEFINE) { 8 9 submit(); 10 11 } 12 13 if (verbose) { 14 15 monitorAndPrintJob(); 16 17 } else { 18 19 // get the completion poll interval from the client. 20 21 int completionPollIntervalMillis = 22 23 Job.getCompletionPollInterval(cluster.getConf()); 24 25 while (!isComplete()) { 26 27 try { 28 29 Thread.sleep(completionPollIntervalMillis); 30 31 } catch (InterruptedException ie) { 32 33 } 34 35 } 36 37 } 38 39 return isSuccessful(); 40 41 }

?

至于方法的參數(shù)verbose,如果想在控制臺打印當(dāng)前的進(jìn)度,則設(shè)置為true。

?? 至于submit方法,如果當(dāng)前在HDFS的配置文件中配置了mapreduce.framework.name屬性為“yarn”的話,會創(chuàng)建一個YARNRunner對象來進(jìn)行任務(wù)的提交。其構(gòu)造方法如下:

1 public YARNRunner(Configuration conf, ResourceMgrDelegate resMgrDelegate, 2 3 ClientCache clientCache) { 4 5 this.conf = conf; 6 7 try { 8 9 this.resMgrDelegate = resMgrDelegate; 10 11 this.clientCache = clientCache; 12 13 this.defaultFileContext = FileContext.getFileContext(this.conf); 14 15 } catch (UnsupportedFileSystemException ufe) { 16 17 throw new RuntimeException("Error in instantiating YarnClient", ufe); 18 19 } 20 21 }

?

其中,ResourceMgrDelegate實(shí)際上ResourceManager的代理類,其實(shí)現(xiàn)了YarnClient接口,通過ApplicationClientProtocol代理直接向RM提交Job,殺死Job,查看Job運(yùn)行狀態(tài)等操作。同時,在ResourceMgrDelegate類中會通過YarnConfiguration來讀取yarn-site.xml、core-site.xml等配置文件中的配置屬性。

?? 下面就到了客戶端最關(guān)鍵的時刻了,提交Job到集群運(yùn)行。具體實(shí)現(xiàn)類是JobSubmitter類中的submitJobInternal方法。這個牛氣哄哄的方法寫了100多行,還不算其幾十行的注釋。我們看它干了點(diǎn)啥。

Step1:

檢查job的輸出路徑是否存在,如果存在則拋出異常。

Step2:

初始化用于存放Job相關(guān)資源的路徑。注意此路徑的構(gòu)造方式為:

1 conf.get(MRJobConfig.MR_AM_STAGING_DIR, 2 3 MRJobConfig.DEFAULT_MR_AM_STAGING_DIR) 4 5 + Path.SEPARATOR + user 6 7 + Path.SEPARATOR + STAGING_CONSTANT

?

其中,MRJobConfig.DEFAULT_MR_AM_STAGING_DIR為“/tmp/hadoop-yarn/staging”,STAGING_CONSTANT為".staging"。

Step3:

設(shè)置客戶端的host屬性:mapreduce.job.submithostname和mapreduce.job.submithostaddress

Step4:

通過RPC,向Yarn的ResourceManager申請JobID對象。

Step5:

從HDFS的NameNode獲取驗(yàn)證用的Token,并將其放入緩存。

Step6:

將作業(yè)文件上傳到HDFS,這里如果我們前面沒有對Job命名的話,默認(rèn)的名稱就會在這里設(shè)置成jar的名字。并且,作業(yè)默認(rèn)的副本數(shù)是10,如果屬性mapreduce.client.submit.file.replication沒有被設(shè)置的話。

Step7:

文件上傳到HDFS之后,還要被DistributedCache進(jìn)行緩存起來。這是因?yàn)橛嬎愎?jié)點(diǎn)收到該作業(yè)的第一個任務(wù)后,就會有DistributedCache自動將作業(yè)文件Cache到節(jié)點(diǎn)本地目錄下,并且會對壓縮文件進(jìn)行解壓,如:.zip,.jar,.tar等等,然后開始任務(wù)。

最后,對于同一個計算節(jié)點(diǎn)接下來收到的任務(wù),DistributedCache不會重復(fù)去下載作業(yè)文件,而是直接運(yùn)行任務(wù)。如果一個作業(yè)的任務(wù)數(shù)很多,這種設(shè)計避免了在同一個節(jié)點(diǎn)上對用一個job的文件會下載多次,大大提高了任務(wù)運(yùn)行的效率。

Step8:

對每個輸入文件進(jìn)行split劃分。注意這只是個邏輯的劃分,不是物理的。因?yàn)榇颂幨禽斎胛募?#xff0c;因此執(zhí)行的是FileInputFormat類中的getSplits方法。只有非壓縮的文件和幾種特定壓縮方式壓縮后的文件才分片。分片的大小由如下幾個參數(shù)決定:mapreduce.input.fileinputformat.split.maxsizemapreduce.input.fileinputformat.split.minsize、文件的塊大小。

具體計算方式為:

Math.max(minSize, Math.min(maxSize, blockSize))

分片的大小有可能比默認(rèn)塊大小64M要大,當(dāng)然也有可能小于它,默認(rèn)情況下分片大小為當(dāng)前HDFS的塊大小,64M。

?? 接下來就該正兒八經(jīng)的獲取分片詳情了。代碼如下:

1 long bytesRemaining = length; 2 3 while (((double) bytesRemaining)/splitSize > SPLIT_SLOP) { 4 5 int blkIndex = getBlockIndex(blkLocations, length-bytesRemaining); 6 7 splits.add(makeSplit(path, length-bytesRemaining, splitSize, 9 blkLocations[blkIndex].getHosts())); 10 11 bytesRemaining -= splitSize; 13 } 15 16 if (bytesRemaining != 0) { 18 int blkIndex = getBlockIndex(blkLocations, length-bytesRemaining); 19 20 splits.add(makeSplit(path, length-bytesRemaining, bytesRemaining, 22 blkLocations[blkIndex].getHosts())); 23 24 }

?

Step8.1

?? 將bytesRemaining(剩余未分片字節(jié)數(shù))設(shè)置為整個文件的長度。

Step8.2

如果bytesRemaining超過分片大小splitSize一定量才會將文件分成多個InputSplit,SPLIT_SLOP(默認(rèn)1.1)。接著就會執(zhí)行如下方法獲取block的索引,其中第二個參數(shù)是這個block在整個文件中的偏移量,在循環(huán)中會從0越來越大:

1 protected int getBlockIndex(BlockLocation[] blkLocations, long offset) { 4 for (int i = 0 ; i < blkLocations.length; i++) { 5 // is the offset inside this block? 6 if ((blkLocations[i].getOffset() <= offset) && 7 (offset < blkLocations[i].getOffset() + blkLocations[i].getLength())){ 8 return i; 9 } 10 } 11 12 BlockLocation last = blkLocations[blkLocations.length -1]; 13 long fileLength = last.getOffset() + last.getLength() -1; 14 throw new IllegalArgumentException("Offset " + offset + " is outside of file (0.." + fileLength + ")"); 17 }

?

將符合條件的塊的索引對應(yīng)的block信息的主機(jī)節(jié)點(diǎn)以及文件的路徑名、開始的偏移量、分片大小splitSize封裝到一個InputSplit中加入List<InputSplit> splits。

Step8.3

bytesRemaining -= splitSize修改剩余字節(jié)大小。剩余如果bytesRemaining還不為0,表示還有未分配的數(shù)據(jù),將剩余的數(shù)據(jù)及最后一個block加入splits。

Step8.4

如果不允許分割isSplitable==false,則將第一個block、文件目錄、開始位置為0,長度為整個文件的長度封裝到一個InputSplit,加入splits中;如果文件的長度==0,則splits.add(new FileSplit(path, 0, length, new String[0]))沒有block,并且初始和長度都為0;

Step8.5

將輸入目錄下文件的個數(shù)賦值給?"mapreduce.input.num.files",方便以后校對,返回分片信息splits。

  這就是getSplits獲取分片的過程。當(dāng)使用基于FileInputFormat實(shí)現(xiàn)InputFormat時,為了提高M(jìn)apTask的數(shù)據(jù)本地性,應(yīng)盡量使InputSplit大小與block大小相同。

? 如果分片大小超過bolck大小,但是InputSplit中的封裝了單個block的所在主機(jī)信息啊,這樣能讀取多個bolck數(shù)據(jù)嗎?

比如當(dāng)前文件很大,1G,我們設(shè)置的最小分片是100M,最大是200M,當(dāng)前塊大小為64M,經(jīng)過計算后的實(shí)際分片大小是100M,這個時候第二個分片中存放的也只是一個block的host信息。需要注意的是split是邏輯分片,不是物理分片,當(dāng)Map任務(wù)需要的數(shù)據(jù)本地性發(fā)揮作用時,會從本機(jī)的block開始讀取,超過這個block的部分可能不在本機(jī),這就需要從別的DataNode拉數(shù)據(jù)過來,因?yàn)閷?shí)際獲取數(shù)據(jù)是一個輸入流,這個輸入流面向的是整個文件,不受split的影響,split的大小越大可能需要從別的節(jié)點(diǎn)拉的數(shù)據(jù)越多,從從而效率也會越慢,拉數(shù)據(jù)的多少是由getSplits方法中的splitSize決定的。所以為了更有效率,分片的大小盡量保持在一個block大小吧。

Step9:

將split信息和SplitMetaInfo都寫入HDFS中。使用方法:

1 JobSplitWriter.createSplitFiles(jobSubmitDir, conf, jobSubmitDir.getFileSystem(conf), array);

?

Step10:

對Map數(shù)目設(shè)置,上面獲得到的split的個數(shù)就是實(shí)際的Map任務(wù)的數(shù)目。

Step11:

相關(guān)配置寫入到j(luò)ob.xml中:

1 jobCopy.writeXml(out);

?

Step12:

通過如下代碼正式提交Job到Y(jié)arn:

1 status = submitClient.submitJob(jobId, submitJobDir.toString(), job.getCredentials());

?

?? 這里就涉及到Y(jié)arnClient和RresourceManager的RPC通信了。包括獲取applicationId、進(jìn)行狀態(tài)檢查、網(wǎng)絡(luò)通信等。

Step13:

上面通過RPC的調(diào)用,最后會返回一個JobStatus對象,它的toString方法可以在JobClient端打印運(yùn)行的相關(guān)日志信息。

4.2.4 另一種運(yùn)行方式

?? 提交MapReduce任務(wù)的方式除了上述源碼中給出的之外,還可以使用ToolRunner方式。具體方式為:

1 ToolRunner.run(new Configuration(),new WordCount(), args);

?

至此,我們的MapReduce的啟動類要做的事情已經(jīng)分析完了。

?

-------------------------------------------------------------------------------

如果您看了本篇博客,覺得對您有所收獲,請點(diǎn)擊右下角的?[推薦]

如果您想轉(zhuǎn)載本博客,請注明出處

如果您對本文有意見或者建議,歡迎留言

感謝您的閱讀,請關(guān)注我的后續(xù)博客

轉(zhuǎn)載于:https://www.cnblogs.com/Scott007/p/3836687.html

總結(jié)

以上是生活随笔為你收集整理的Mapreduce执行过程分析(基于Hadoop2.4)——(一)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

欧美一区二区精品在线 | 国产一二区在线观看 | 午夜久久美女 | 久久一级电影 | 国产免费久久 | 精品欧美一区二区三区久久久 | 色综合婷婷久久 | 91精品国产91热久久久做人人 | 五月婷香 | 天天爽天天射 | 五月激情久久 | 美女精品| 国产人成看黄久久久久久久久 | 欧美在线a视频 | 又黄又爽又刺激视频 | 国产在线免费av | 视频 天天草 | 免费观看www7722午夜电影 | 97人人澡人人爽人人模亚洲 | 免费看三级黄色片 | 2023国产精品自产拍在线观看 | 一本一本久久a久久 | 四虎成人精品 | 国产99久久久国产精品免费二区 | 懂色av懂色av粉嫩av分享吧 | 国产精品久久久久影视 | 国产精品久久久久久久久久东京 | 久久久久久久久久久高潮一区二区 | 精品欧美一区二区三区久久久 | 欧美成人999 | 久久视精品 | 亚洲一区二区三区91 | 狠狠网 | 欧美精品日韩 | 国内精品免费久久影院 | 久久影院一区 | 人人爽人人爽 | 99久久婷婷国产一区二区三区 | 久久亚洲成人网 | 中文字幕色综合网 | 国产又粗又猛又黄又爽 | 欧洲av不卡 | 日本高清免费中文字幕 | 国产美女精品久久久 | 最新婷婷色 | 国产一级a毛片视频爆浆 | 国产精品一区二区免费在线观看 | 国产精品精品久久久久久 | 香蕉久久久久久av成人 | 二区中文字幕 | 久久撸在线视频 | 国产精久久久久久久 | 日韩理论在线视频 | 九九热视频在线免费观看 | 亚洲国产中文字幕在线 | 在线国产视频一区 | 免费看片网址 | 久久99国产精品二区护士 | 国产在线资源 | 日韩一区二区三区高清免费看看 | 97色婷婷成人综合在线观看 | 午夜精品久久久久久久久久 | 国内外成人免费在线视频 | 在线观看的黄色 | 日本不卡123区 | 香蕉在线影院 | 天天爽天天射 | 日韩一区二区三区在线看 | 久久久黄视频 | 综合色狠狠 | 999视频精品| 欧美性色综合网 | av在线超碰 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 久久香蕉电影网 | 黄色国产高清 | av中文天堂| 天天天操操操 | 久久一区二 | 中文字幕区| 久久av免费电影 | 超碰大片 | 国产精品一区二区美女视频免费看 | 成人免费在线视频观看 | 超碰在线99 | 一区二区三区四区精品 | 丝袜美女视频网站 | av不卡免费在线观看 | 国产手机视频在线观看 | 日本爱爱免费 | 日韩网站在线 | 亚洲亚洲精品在线观看 | 日本女人b | 久免费| 成人久久18免费网站图片 | 黄色毛片观看 | 伊人久久一区 | 国产黄色一级片 | 国产成人91| 欧美精品久久久久久久久久 | 狠狠狠狠狠狠狠狠干 | 亚洲精品视频网 | 91福利视频一区 | 最近中文字幕国语免费高清6 | 午夜影院一级片 | 在线观看黄av | 视频1区2区 | 日韩欧美高清在线观看 | 福利电影一区二区 | 久久免费av | 天天操操操操操 | 91高清完整版在线观看 | 久久首页 | 911国产在线观看 | 日夜夜精品视频 | 九九热在线播放 | 日韩激情片在线观看 | 免费av网站在线看 | 天天天天干 | 国产精品永久免费在线 | 中文字幕在线观看一区二区三区 | 91福利视频在线 | 精品国产aⅴ麻豆 | 久久久久久毛片 | 日韩免费观看一区二区 | 国产视频网站在线观看 | 色婷婷a | 在线一二三区 | 国产白浆在线观看 | 一区二区三区在线观看免费 | 欧美日韩高清一区二区 国产亚洲免费看 | 久操中文字幕在线观看 | 亚洲国产成人在线播放 | 五月婷婷一区二区三区 | 国产a级精品 | 国产一性一爱一乱一交 | www.超碰97.com | 青青河边草手机免费 | 又黄又刺激视频 | 毛片www | 精品91视频 | 欧美日韩免费看 | 欧美一二三区播放 | 久久久99精品免费观看 | 91三级视频 | 久久久免费 | 久久av影视 | 日韩色在线 | 日韩精品视频在线观看网址 | 热久久精品在线 | www在线免费观看 | 精品国产成人在线 | 日韩高清在线观看 | 一区二区丝袜 | 国产免费又爽又刺激在线观看 | 六月天色婷婷 | 色偷偷97| 在线免费色 | 欧美日韩国产在线一区 | 国产高清精 | 在线免费观看麻豆视频 | 欧美日韩亚洲第一页 | 网站在线观看你们懂的 | 日韩视频1区 | 999国产在线 | a级片久久| 视频一区二区在线 | 亚洲黄色激情小说 | 久久天天躁| 国产精品久久艹 | 91成人破解版| 波多野结衣视频一区二区 | 久久久久久久久久免费 | 亚洲日本精品视频 | 久久精品99精品国产香蕉 | 久要激情网| 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 开心色激情网 | av免费在线观看网站 | 综合色天天 | 欧美日韩不卡在线观看 | 成人性生交大片免费观看网站 | 亚洲精品国偷拍自产在线观看蜜桃 | 91看片麻豆| www婷婷| 天天综合网久久综合网 | 国产精品区一区 | 国产一线在线 | 亚洲网站在线 | 521色香蕉网站在线观看 | 日韩视频在线一区 | 中文字幕在线一区观看 | 成人影片在线免费观看 | 综合网成人| 免费麻豆网站 | 国产成人亚洲精品自产在线 | 伊人久久av | 欧美日韩高清免费 | 亚洲区视频在线 | 日本中文字幕在线视频 | av免费片| 欧美精品一区二区在线观看 | 色噜噜在线观看 | 黄在线免费观看 | 在线观看的av | 91资源在线视频 | 欧美日韩国产欧美 | 国产精品久久久久久久久久久久午 | 日韩午夜大片 | 中文日韩在线 | 欧美精品二 | 欧美日本啪啪无遮挡网站 | 国产在线观看91 | 欧美一级久久久久 | 久久精品亚洲精品国产欧美 | 久久久久这里只有精品 | 久久久天堂 | 黄色小说免费在线观看 | 日韩视频一区二区在线 | 国产色在线视频 | 毛片随便看 | 免费看的黄色片 | 日韩毛片在线免费观看 | 在线观看视频免费大全 | 天天射射天天 | 色www精品视频在线观看 | 九九精品视频在线观看 | 日韩在线视频一区二区三区 | 色久五月 | 又黄又刺激的网站 | 欧美小视频在线 | 成年人视频在线免费播放 | 国产理论在线 | 日本中文字幕系列 | 久久精品影视 | 永久免费毛片 | 丰满少妇在线观看网站 | av一级久久 | 久久久国产精品亚洲一区 | 天天爱天天草 | 日韩电影中文 | 日韩网页| 国产免费av一区二区三区 | 国产精品久久久久aaaa九色 | 少妇搡bbbb搡bbb搡忠贞 | 国产女教师精品久久av | 91成年人在线观看 | 国产亚洲精品成人av久久影院 | 九草在线视频 | 在线观看视频福利 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 狠狠色丁香婷婷综合最新地址 | 久久久久久久久爱 | 久久精品国产精品亚洲 | 国产不卡免费av | 国产成人久久精品亚洲 | 美女视频网站久久 | 日韩久久电影 | 一区二区精| 午夜精品视频一区二区三区在线看 | 国产美女精品久久久 | 制服丝袜一区二区 | 国产男女免费完整视频 | 国产一区不卡在线 | 欧美激情视频一区 | av成人黄色 | 国产视频二区三区 | 国产精品va在线播放 | 国产成人不卡 | 久久久久久在线观看 | 视频在线日韩 | 亚洲国产精品小视频 | 欧美日本不卡 | 啪啪肉肉污av国网站 | 久久综合欧美精品亚洲一区 | 亚洲天堂网在线视频 | 日本成人免费在线观看 | 四虎在线观看精品视频 | 特级毛片在线 | 一区二区伦理电影 | 成人国产在线 | 欧美日韩国产一二三区 | 欧美日韩国产免费视频 | 91av影视 | 日韩欧美高清在线观看 | 国产一卡二卡在线 | 玖玖爱国产在线 | 免费午夜网站 | 8x成人免费视频 | 日韩黄色在线 | 丁香激情婷婷 | 亚洲女人天堂成人av在线 | 久久国产电影院 | 天天天操操操 | 成年人在线免费看片 | 国产精品久久av | 色中文字幕在线观看 | 91在线看黄 | 久草爱| 中文字幕一区二区三区四区在线视频 | 中文字幕之中文字幕 | 国产亚洲在线观看 | 亚洲国产精品99久久久久久久久 | 高清精品在线 | 亚洲少妇自拍 | 免费看的av片 | 婷婷久久久 | 日韩在线高清免费视频 | 国产91影视 | 91精品老司机久久一区啪 | 9999在线视频 | 久久久免费精品视频 | 国产精品久久久久久久久久久不卡 | 成人国产精品av | 久草手机视频 | 五月天国产 | 四虎在线观看 | 国产日韩欧美在线看 | 国产精品色在线 | 欧美日韩后| 开心色激情网 | 丝袜美腿在线视频 | 国产精品麻豆免费版 | 中文十次啦| 久久综合欧美精品亚洲一区 | 91视频在线免费下载 | 国产大尺度视频 | 日韩激情在线视频 | 香蕉视频国产在线 | 欧美日韩高清在线 | 日本资源中文字幕在线 | 精品久久1| 天天干,天天射,天天操,天天摸 | 国产成人一区二区三区电影 | 欧美激情va永久在线播放 | 欧美日韩亚洲在线观看 | 亚洲国产欧美在线看片xxoo | 天天操天天操天天操 | 日本不卡一区二区三区在线观看 | 成人黄色毛片 | 国产护士hd高朝护士1 | 国产精品久久久久一区二区国产 | 日韩精品一区二区免费 | 亚洲一区二区三区91 | 久久国产手机看片 | 国产高清av免费在线观看 | 久久精品国产一区二区电影 | 国产亚洲精品久久久久久网站 | 中文乱码视频在线观看 | 91福利区一区二区三区 | 日韩精选在线 | 天天天操天天天干 | 成人观看视频 | 五月天网页| av短片在线观看 | 成人a级黄色片 | 超碰成人av | а中文在线天堂 | 日韩毛片一区 | 婷婷电影在线观看 | 中文字幕一区二区三区久久 | 精品视频9999| 97成人免费 | 亚洲精品88欧美一区二区 | 亚洲精品乱码久久久一二三 | 91大片成人网 | 国产91区| 在线观看免费日韩 | 国产精品毛片久久久 | 国产精品久久久久久久久久东京 | 久久亚洲综合国产精品99麻豆的功能介绍 | 开心激情五月网 | 国产色女人 | 在线视频 一区二区 | 日韩精品久久久久久中文字幕8 | 久久手机免费视频 | 国产91对白在线播 | 丁香久久综合 | 在线观看免费视频你懂的 | 99久久精品免费视频 | 中文字幕资源网 国产 | 91成人在线网站 | 操久| 久久久久看片 | 三级a视频 | 精品久久五月天 | 日本婷婷色| 91片在线观看| 亚洲自拍偷拍色图 | 一区二区三区av在线 | 在线a人片免费观看视频 | 成人h动漫在线看 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 久草视频视频在线播放 | 国产字幕av | 久久福利剧场 | 亚洲精品日韩在线观看 | 香蕉精品视频在线观看 | 国产欧美在线一区 | 91精品视频一区 | 2019免费中文字幕 | 五月婷婷视频在线 | 国产精彩视频一区二区 | 97在线观看免费观看 | 午夜123| 天天视频亚洲 | 在线a人片免费观看视频 | 精品资源在线 | 91精品国产欧美一区二区成人 | 超碰在线免费福利 | 五月婷婷狠狠 | 亚洲3级| 国产一区私人高清影院 | 亚洲一区欧美精品 | 国产精品99蜜臀久久不卡二区 | 天天操天天摸天天爽 | 在线观看一级片 | 在线免费色| 国产免费国产 | 99re中文字幕 | 91九色视频在线播放 | 日本mv大片欧洲mv大片 | 在线亚洲观看 | 色综合久久久久综合体 | 人人狠狠综合久久亚洲婷 | 午夜久操 | 五月激情婷婷丁香 | 久久国产二区 | 91av在线免费播放 | 国产精品久久久久一区二区三区 | 在线免费观看麻豆 | 97狠狠操 | 国产黄色免费 | 国产精品手机在线观看 | 日韩欧美高清免费 | 人人澡人人添人人爽一区二区 | 中文字幕一区二区三区视频 | 国产美女精品在线 | 欧美日韩一区二区三区视频 | 成人午夜性影院 | 欧美午夜一区二区福利视频 | 成人av电影在线 | 99国内精品| 日韩毛片久久久 | 国产小视频精品 | 亚洲激情视频在线观看 | 亚洲人在线7777777精品 | 亚洲精品久久久久中文字幕m男 | 中文字幕免费看 | 亚洲国产中文字幕 | 亚洲热久久 | 九九热精品国产 | 在线免费黄网站 | 成人免费91 | 五月天九九 | 日日躁夜夜躁xxxxaaaa | 欧美韩日视频 | 精品视频免费看 | 色视频一区 | 国产精品一区专区欧美日韩 | 日韩一级成人av | 中文字幕一区二区在线观看 | 欧美精彩视频在线观看 | 久久一精品 | 欧美亚洲三级 | 狠狠色丁香婷婷综合久小说久 | 91久久精品日日躁夜夜躁国产 | 中文字幕在线网址 | 久久精品电影网 | 国产 日韩 欧美 中文 在线播放 | 久久激情五月丁香伊人 | 午夜性盈盈 | 色是在线视频 | sm免费xx网站| 午夜狠狠操 | 人人爽人人爽av | 婷婷网站天天婷婷网站 | 看片黄网站 | 中文字幕一区在线观看视频 | 日韩久久久久久久久 | 亚洲精品在线一区二区三区 | 在线观看va | 国产剧在线观看片 | 国产亚洲精品久久久久久无几年桃 | 91三级视频 | 国产永久免费 | 欧美日在线观看 | 国产精品精品国产 | 婷婷六月综合亚洲 | 日韩中文字幕第一页 | 九九国产精品视频 | 18国产精品白浆在线观看免费 | 色婷婷啪啪免费在线电影观看 | 午夜精品福利一区二区 | 婷婷丁香六月 | 色哟哟国产精品 | 91热这里只有精品 | 色综合天天爱 | 日韩一区二区三区高清在线观看 | 五月天婷婷免费视频 | 91黄色在线看 | 99国产一区二区三精品乱码 | 俺要去色综合狠狠 | 国产一区二区在线观看视频 | 国产亚洲成人精品 | 91在线中文字幕 | 最近中文字幕高清字幕免费mv | 精品国产一区二区三区免费 | 久久久免费电影 | 91av在线视频播放 | 日本久久免费电影 | 91mv.cool在线观看 | 日韩精品久久久 | 麻豆传媒视频在线免费观看 | 国产啊v在线 | 亚洲综合在线一区二区三区 | 久久这里只有精品首页 | 青青河边草免费观看 | 人人爽人人看 | 色婷婷狠狠干 | 久久久久久久毛片 | 国产在线观看av | 日韩三级一区 | 韩国精品福利一区二区三区 | 中文字幕在线一二 | 日韩中文在线视频 | 在线中文字幕一区二区 | 色av婷婷 | 丁香 婷婷 激情 | 色综合天天综合 | 国产一级片免费观看 | 三上悠亚一区二区在线观看 | 天天操综合 | 亚洲激情在线观看 | 丝袜+亚洲+另类+欧美+变态 | 久久久网| 欧美伦理电影一区二区 | 中文字幕在线视频一区 | 中文字幕亚洲欧美 | 国产福利午夜 | 亚洲撸撸| 国产日韩视频在线 | 久久影院精品 | 亚洲免费精品视频 | 国产专区第一页 | 亚洲国产人午在线一二区 | 人人插人人插 | 国产一级片视频 | 在线观看视频中文字幕 | 波多野结衣一区二区 | 国产精品一区一区三区 | 超碰人人在| 成人精品亚洲 | 欧美在线18 | www.夜夜爽| 欧美日韩中文国产一区发布 | 日韩中文字幕视频在线观看 | 日本视频精品 | 在线视频观看国产 | 中文字幕在线看视频国产中文版 | 波多野结衣电影久久 | 天天综合入口 | 亚洲精品高清视频 | 精品国产一区二区三区久久 | 安徽妇搡bbbb搡bbbb | 欧美一区二区精品在线 | 人人狠狠综合久久亚洲 | 免费在线激情视频 | 久久av不卡| 国产99久久九九精品免费 | 黄色一级影院 | 亚洲成人av免费 | 在线精品视频免费播放 | 亚洲精品mv在线观看 | 欧美永久视频 | 一区在线免费观看 | 夜添久久精品亚洲国产精品 | 久久亚洲欧美 | 在线草 | 久久99九九99精品 | 在线免费观看成人 | 国产精品成人久久 | 国产成人精品一区二区在线观看 | 在线v片免费观看视频 | 综合网成人 | 中文字幕免费高 | 五月天综合网站 | av三级在线免费观看 | 国产免费久久av | 精品国模一区二区三区 | 国产999精品久久久影片官网 | 成人av免费播放 | 九九热免费视频在线观看 | 97超碰在线免费 | 久久精品久久99精品久久 | 精品国产福利在线 | 成人黄色电影在线观看 | 国产一二三区av | 国产区高清在线 | 精品成人a区在线观看 | 亚洲精品动漫久久久久 | 成人一级免费电影 | 五月天激情综合网 | 免费电影一区二区三区 | 91日韩精品视频 | 国产精品久久久久影院 | 久久久性 | 日日麻批40分钟视频免费观看 | 麻花豆传媒一二三产区 | 97色se | 久久色网站 | 日韩理论在线观看 | 手机看片国产 | 欧美精品乱码久久久久久按摩 | 国产又粗又猛又爽又黄的视频先 | 伊人av综合 | 欧美激情视频在线免费观看 | 五月天婷婷免费视频 | 在线播放视频一区 | 玖玖在线播放 | 日韩视频免费观看高清完整版在线 | 国产精品18久久久久久不卡孕妇 | 激情网色 | 国产精品24小时在线观看 | 在线观看你懂的网站 | 黄色av电影在线 | 欧美日韩性视频在线 | 亚洲精品在线免费 | 中文字幕av影院 | 99久久综合精品五月天 | 精品亚洲成人 | av高清在线 | 国产精品久久久久久模特 | 日韩免费高清在线观看 | 成人久久精品 | 看片在线亚洲 | 日韩亚洲欧美中文字幕 | 国产精品v欧美精品v日韩 | 国产亚洲欧美精品久久久久久 | 成人九九视频 | 亚洲日韩欧美一区二区在线 | 日韩精品在线观看视频 | 婷婷丁香花| 欧美日韩国产一区二区三区在线观看 | 国产精品久久一区二区无卡 | www国产亚洲精品久久麻豆 | 成人午夜电影网 | av五月婷婷 | 中文字幕免费一区二区 | 色网免费观看 | 日韩精品久久久久久久电影99爱 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 毛片.com| 亚洲日本va中文字幕 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 久久国产精品精品国产色婷婷 | 精品v亚洲v欧美v高清v | 九九热免费在线观看 | 亚洲国产精品成人va在线观看 | 久久久黄色av | 国产亚洲精品免费 | 久久福利精品 | 久久国产精品视频 | 久操视频在线播放 | 精品一区二三区 | 国产一级片免费播放 | 国产1区2区 | 日韩中文在线观看 | 91精品视频免费观看 | 亚洲国产精品电影在线观看 | 国产在线观看你懂得 | 婷婷综合成人 | 天天色天天射天天综合网 | 欧美日韩精品在线观看视频 | 五月婷婷六月丁香激情 | av成人动漫在线观看 | 日产乱码一二三区别在线 | 免费观看全黄做爰大片国产 | 久久久资源| 在线视频日韩精品 | 成人国产在线 | 丁香六月久久综合狠狠色 | 成人av资源网 | 国产中文字幕视频在线 | 国语麻豆 | 91在线观看黄 | 91免费高清观看 | 最新婷婷色 | 一区二区三区免费在线观看视频 | 免费热情视频 | 黄色影院在线播放 | 狠狠躁日日躁狂躁夜夜躁av | 99爱在线观看 | 伊人va| 国产成人av网址 | 97超碰成人在线 | 视频三区在线 | 欧美资源在线观看 | 久久精品99国产精品亚洲最刺激 | 久草综合在线观看 | 欧美日高清视频 | 成人影片免费 | 国产高清小视频 | 中文字幕一区二区三区精华液 | 精品亚洲二区 | 免费黄色看片 | 国产综合香蕉五月婷在线 | 永久av免费在线观看 | 三级动态视频在线观看 | 久久精品99国产精品酒店日本 | 中文字幕在线视频第一页 | 久久99中文字幕 | 天天搞夜夜骑 | 黄色成人av| 亚洲狠狠 | 婷婷色在线视频 | 91在线区| 欧美福利片在线观看 | 91人人揉日日捏人人看 | 欧美日韩国产二区三区 | 国产精品久久久久高潮 | 国产精品99久久99久久久二8 | 亚洲精品小视频 | 国产中文字幕91 | 国产中文视 | 国产美女免费看 | 伊人色播 | av电影在线播放 | 伊人一级 | 97超碰在线免费 | 一区二区视频电影在线观看 | 亚洲国产精品资源 | 好看的国产精品视频 | 操夜夜操| 国产精品免费一区二区三区 | 激情五月***国产精品 | 99热国产在线 | 欧美日韩免费观看一区=区三区 | 午夜少妇| 亚洲国产免费网站 | 日韩免费区 | 亚洲在线视频免费 | 青青河边草观看完整版高清 | 看片的网址| 国产xvideos免费视频播放 | 亚洲精品综合一二三区在线观看 | 高清日韩一区二区 | 久久看视频 | 天天射成人 | 狠狠狠狠狠色综合 | 二区视频在线观看 | 玖玖爱免费视频 | 日韩精品黄 | 黄网站污 | 欧美日韩不卡一区二区 | 精品久久网 | 国产精品人人做人人爽人人添 | 欧美视频网址 | 亚洲精品乱码久久久一二三 | 在线观看免费一级片 | 99久久久国产精品 | www.夜夜爽 | 日日爱影视 | 国产一区在线观看免费 | 久99久精品 | 久久y| 99久久综合精品五月天 | 精品国产一区二区三区久久影院 | 欧美国产日韩激情 | 久久观看免费视频 | 国产在线毛片 | 午夜久久视频 | 日日干激情五月 | 亚洲乱码久久 | 国产女教师精品久久av | 国产精品96久久久久久吹潮 | 丁香网婷婷 | 麻豆视频在线观看免费 | 99久久久国产精品免费99 | 国产麻豆精品95视频 | 五月婷香蕉久色在线看 | 91精品啪在线观看国产81旧版 | 久久久久久久影视 | 国产日产av| 欧美日韩不卡一区二区三区 | 国产亚洲91 | 日韩av高潮 | 狠狠狠色丁香综合久久天下网 | 国产69久久久欧美一级 | 天天草综合网 | 808电影免费观看三年 | 国产在线综合视频 | 91在线国产观看 | 天天操天天摸天天射 | 在线观看不卡视频 | 草久久久久久 | 天天干天天射天天插 | 精品国产精品国产偷麻豆 | 成人免费视频网 | 91九色在线播放 | 手机av看片 | 国产 日韩 欧美 在线 | 成人一区二区在线观看 | 国产精品免费观看久久 | 色香蕉在线 | 国产99久久精品一区二区永久免费 | 国产精品高潮呻吟久久久久 | 国产精品久久久久久电影 | 超碰99人人| 久久精品视频网站 | 欧美日韩一区二区三区不卡 | 日韩精品免费在线观看视频 | 奇米7777狠狠狠琪琪视频 | 亚洲性xxxx | 五月天综合网站 | 337p西西人体大胆瓣开下部 | 国产18精品乱码免费看 | 中文字幕日韩国产 | 香蕉视频4aa | 69国产精品视频 | 国产一级大片在线观看 | 国产在线精品区 | 成人亚洲网 | av一级在线| 免费看亚洲毛片 | 91麻豆精品国产午夜天堂 | 亚洲成人午夜在线 | 久久久久婷 | 黄色电影在线免费观看 | 亚洲精品综合在线观看 | 一区二区三区在线播放 | 国产a免费 | 99热最新网址 | 一区二区三区在线免费观看视频 | 久久好看| 成人在线视频论坛 | 欧美另类美少妇69xxxx | 欧美日韩不卡在线 | 久久精选视频 | 四虎免费在线观看 | 午夜精品一区二区国产 | 成年人视频免费在线播放 | 九九九热精品免费视频观看网站 | 国产精品成人自产拍在线观看 | 成人国产精品一区 | 婷婷六月丁 | 久久综合九色99 | 亚洲欧美婷婷六月色综合 | 免费人做人爱www的视 | 国产精品一区二区av | www操操操| 亚洲 欧美 综合 在线 精品 | 不卡日韩av | 午夜影院先 | 欧美日高清视频 | 黄色影院在线播放 | 国产精品不卡一区 | 国产精品福利无圣光在线一区 | 久久久精品免费观看 | 亚洲一区二区三区精品在线观看 | 欧美a影视 | 美女一级毛片视频 | 久久久久久久久毛片 | 日韩一区二区三区在线看 | 激情久久久久久久久久久久久久久久 | 国产精品久久久久久久免费观看 | 黄色三级免费 | 久久国产精品影片 | 最近中文字幕免费视频 | 综合久久网| 中文字幕资源网 国产 | 国产乱码精品一区二区蜜臀 | 国产精品一区二区久久久久 | 日本久久久久久 | 国产色秀视频 | 免费观看黄色av | 精品一区电影国产 | 99久热 | 黄色在线免费观看网站 | 92av视频| 看片一区二区三区 | 国产成人av电影在线 | 高清不卡免费视频 | 日韩视频三区 | 视频一区视频二区在线观看 | 国产精品av电影 | 亚洲欧美激情插 | 国产视频在线观看一区 | 欧美午夜精品久久久久久浪潮 | 97超碰人人澡人人 | 亚洲国产中文字幕在线观看 | 亚洲免费av一区二区 | 久久亚洲私人国产精品va | 亚洲国产精品传媒在线观看 | 91亚洲精品久久久蜜桃网站 | 尤物九九久久国产精品的分类 | 成人黄色电影免费观看 | 免费高清看电视网站 | 97超碰色| 天天综合天天综合 | 99一级片| 二区三区在线观看 | 日韩欧美视频免费在线观看 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 一区二区三区精品在线 | 日韩成人av在线 | 91精品视频一区二区三区 | 日本三级在线观看中文字 | av一级片网站 | 久久成人高清视频 | 日韩视频在线观看免费 | 91丨九色丨国产丨porny精品 | 国产精品久久久久久久久久 | 国产区精品视频 | 婷婷亚洲综合五月天小说 | 日韩一区二区三区在线观看 | 日韩综合视频在线观看 | 超碰在线观看av | 国产中文字幕视频在线观看 | 一区在线观看 | 亚洲黄网站 | 日本在线观看中文字幕 | 国产黄色片一级 | 四虎在线观看精品视频 | 国产午夜免费视频 | 免费在线观看av网址 | 精品视频资源站 | 日韩在线观看电影 | 亚洲无吗天堂 | 久久久久久久久黄色 | 午夜电影久久 | 国产精品igao视频网入口 | 日韩在线视频播放 | 888av | 日韩91精品 | 丁香午夜| 日日夜日日干 | 一区二区三区视频网站 | 国产精品白浆视频 | 在线天堂视频 | 69精品久久 | 97福利视频| 国产亚洲精品成人av久久ww | 精品国模一区二区 | 欧美专区日韩专区 | 六月丁香社区 | 亚洲精品一区二区三区在线观看 | 97超级碰 | 日韩欧美高清免费 | 福利一区视频 | 天天爱天天 | 在线观看中文 | 国产精品久久久毛片 | 国产精品1区2区在线观看 | 国产91av视频在线观看 | 亚州精品一二三区 | 在线播放第一页 | 最新国产精品亚洲 | 在线播放 日韩专区 | 久久精品中文字幕少妇 | 国产一区精品在线观看 | 国产一区在线看 | 午夜精品久久久久久99热明星 | 欧美日韩在线看 | 99久久精品电影 | 亚洲精品乱码久久久久久按摩 | 久章草在线 | av在线播放亚洲 | 国产日韩精品一区二区在线观看播放 | 婷婷六月丁| 国产视频资源在线观看 | 国产在线高清精品 | 精品国产福利在线 | 婷婷国产v亚洲v欧美久久 | 国产 中文 日韩 欧美 | 久草99| 最近免费在线观看 | 91av影视 | 欧美大片aaa | 96看片| 麻豆成人在线观看 | 中文字幕欧美三区 | 在线观看av片 | 成人毛片一区 | 久久在线精品 | 久久五月天色综合 | 九九热在线观看视频 | 国产精品久久久99 | 亚洲国产精品一区二区久久hs | 在线中文字幕一区二区 | 最新日韩电影 | 在线电影av| 91九色视频导航 | 精品在线一区二区三区 | 亚洲精品午夜国产va久久成人 | 国产精品中文字幕在线播放 | 婷婷四房综合激情五月 | 日韩在线三级 |