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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Hadoop学习记录(4)|MapReduce原理|API操作使用

發(fā)布時間:2025/3/13 编程问答 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Hadoop学习记录(4)|MapReduce原理|API操作使用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

MapReduce概念

MapReduce是一種分布式計算模型,由谷歌提出,主要用于搜索領(lǐng)域,解決海量數(shù)據(jù)計算問題。

MR由兩個階段組成:Map和Reduce,用戶只需要實(shí)現(xiàn)map()和reduce()兩個函數(shù)實(shí)現(xiàn)分布式計算。

這兩個函數(shù)的形參是key,value對,表示函數(shù)的輸入信息。

MP執(zhí)行流程

客戶端提交給jobtracker,jobtracker分配給tasktracker。

trasktracker會對任務(wù)進(jìn)行mapper和reducer操作。

MapReduce原理

一個map輸入k1、v1,數(shù)據(jù)由輸入文件中獲取

map會把數(shù)據(jù)提交到每一個shuffle,最后輸出到reducer任務(wù)。

reducer任務(wù)的數(shù)量跟mapper發(fā)送到shuffle的數(shù)量是一致的。

map任務(wù)處理

1.1、讀取輸入文件內(nèi)容,解析成key,value對。對輸入文件的每一個解析成key\value對。每個鍵值對調(diào)用一次map函數(shù)。

1.2、寫自己的邏輯,對輸入的key、value處理,轉(zhuǎn)換成新的key、value輸出。

1.3、對輸出的key、value進(jìn)行分區(qū)

1.4、對不同分區(qū)的數(shù)據(jù)按照key進(jìn)行排序、分組。相同key的value放到一個集合中。

1.5、(可選)分組后對數(shù)據(jù)進(jìn)行規(guī)約

reduce任務(wù)處理

2.1、對多個map任務(wù)的輸出按照不同的分區(qū)通過網(wǎng)絡(luò)拷貝到reduce節(jié)點(diǎn)。

2.2、對多個map任務(wù)輸出進(jìn)行合并、排序。寫reduce函數(shù)自己的邏輯,對輸入key、value處理,轉(zhuǎn)換成新的key、value輸出。

2.3、把輸出的結(jié)果保存到HDFS中。

MapReduce執(zhí)行過程

1.1.讀取hdfs中文件,每個解析成<k,v>。每一個鍵值對調(diào)用一次map函數(shù)。

解析成兩個<k,v>,分別<0,hello you><10,hello me>。調(diào)用map函數(shù)兩次。

k是每行的開始位置,v則示每行的文本內(nèi)容。

1.2.覆蓋map()函數(shù),接收1.1產(chǎn)生的<k,v>,進(jìn)行處理,轉(zhuǎn)換新的<k,v>輸出。

1.3.對1.2輸出的<k,v>進(jìn)行分區(qū)

public void map(k,v,context){

String[] split = v.toString().split(“ ”);

for(String str : split){

context.write(str,1);

}

}

1.4.對不同分區(qū)中的數(shù)據(jù)進(jìn)行排序(按照k)、分組,分別將key的value放到一個集合中。

map輸出后的數(shù)據(jù)是:<hello,1]>,<you,1>,<hello,1>,<me,1>

排序后: <hello,1]>, <hello,1>,<you,1>,<me,1>

分組后:<hello,{1,1}>,<you,{1}>,<me,{1}>

1.5.(可選)對分組后的數(shù)據(jù)進(jìn)行規(guī)約。

2.1.多個map任務(wù)的輸出按照不同的分區(qū),通過網(wǎng)絡(luò)copy到不同的reduce節(jié)點(diǎn)上。

2.2.對多個map的輸出進(jìn)行合并,排序,覆蓋reduce函數(shù),接收的是分組的數(shù)據(jù),實(shí)現(xiàn)自己的業(yè)務(wù)邏輯,處理后產(chǎn)生新的<k,v>輸出。

reduce函數(shù)被調(diào)用3次,跟分組次數(shù)一致。

public void reduce(k,vs,context){

long sum =0L;

for(long num:vs){

sum +=num;

}

context.write(k,sum);

}

2.3.設(shè)置任務(wù)執(zhí)行,對reduce輸出的<k,v>保存到hdfs中。

job.waitForCompletion(true);

?

整個流程我分了四步。簡單些可以這樣說,每個map task都有一個內(nèi)存緩沖區(qū),存儲著map的輸出結(jié)果,當(dāng)緩沖區(qū)快滿的時候需要將緩沖區(qū)的數(shù)據(jù)以一個臨時文件的方式存放到磁盤,當(dāng)整個map task結(jié)束后再對磁盤中這個map task產(chǎn)生的所有臨時文件做合并,生成最終的正式輸出文件,然后等待reduce task來拉數(shù)據(jù)。

MapReduce提交的源代碼分析

waitForCompletion函數(shù)中的submit方法連接和提交到j(luò)obtracker。

在eclipse中寫的代碼如何提交到JobTracker中的哪?

答(1)eclipse中調(diào)用的job.waitForCompletion(true),實(shí)際調(diào)用的是JobClient中的提交方法。

contect()

info = jobClient.submitJobInternal(conf)

(2)在contect()中,實(shí)際創(chuàng)建了一個JobClient對象,在調(diào)用該對象的構(gòu)造方法時,獲得了JobTracker的客戶端代理對象JobSubmissionProtocol

jobSubmissionProtocol實(shí)現(xiàn)類是JobTracker

(3)在jobClient.submitJobInternal(conf)方法中,調(diào)用了jobSubmissionProtocol.submitJob()

即,執(zhí)行的是JobTracker.submitJob(..)

Hadoop基本類型

Hadoop數(shù)據(jù)類型必須實(shí)現(xiàn)Writable接口。

Long LongWritable

Boolean BooleanWritable

String Text

Integer IntWritable

Java類型轉(zhuǎn)換為Hadoop基本類型:

直接調(diào)用hadoop類的構(gòu)造方法,或者調(diào)用set()方法

new IntWritable(123)

Hadoop類型轉(zhuǎn)換成Java類型:

text需要調(diào)用toString方法

其他類型調(diào)用get()方法

使用Hadoop自定義類型處理手機(jī)上網(wǎng)流量

1、自定義類

class KpiWritable implements Writable{

long upPackNum;

long downPackNum;

long upPayLoad;

long downPayLoad;

public KpiWritable() {}

public KpiWritable(String upPackNum,String downPackNum,String upPayLoad,String downPayLoad){

this.upPackNum = Long.parseLong(upPackNum);

this.downPackNum = Long.parseLong(downPackNum);

this.upPayLoad = Long.parseLong(upPayLoad);

this.downPayLoad = Long.parseLong(downPayLoad);

}

@Override

public void write(DataOutput out) throws IOException {

//序列化出去

out.writeLong(upPackNum);

out.writeLong(downPackNum);

out.writeLong(upPayLoad);

out.writeLong(downPayLoad);

}

@Override

public void readFields(DataInput in) throws IOException {

//順序和寫出去一樣

this.upPackNum = in.readLong();

this.downPackNum = in.readLong();

this.upPayLoad = in.readLong();

this.downPayLoad = in.readLong();

}

@Override

public String toString() {

return upPackNum+"\t"+downPackNum+"\t"+upPayLoad+"\t"+downPayLoad;

}

2、自定義Map

static class MyMapper extends Mapper<LongWritable, Text, Text, KpiWritable>{

protected void map(LongWritable k1, Text v1,

org.apache.hadoop.mapreduce.Mapper<LongWritable,Text,Text,KpiWritable>.Context context)

throws IOException, InterruptedException {

//處理接收的數(shù)據(jù)

String[] splits = v1.toString().split("\t");

//獲取手機(jī)號

String msisdn = splits[1];

Text k2 = new Text(msisdn);

KpiWritable v2 = new KpiWritable(splits[6],splits[7],splits[8],splits[9]);

//寫入context中交過reduce執(zhí)行

context.write(k2, v2);

}

}

3、自定義Reduce

static class MyReduce extends Reducer<Text, KpiWritable, Text, KpiWritable>{

protected void reduce(Text k2, Iterable<KpiWritable> v2s,org.apache.hadoop.mapreduce.Reducer<Text, KpiWritable, Text, KpiWritable>.Context context)

throws IOException, InterruptedException {

/**

* k2 表示不同的手機(jī)號

* v2s 表示該手機(jī)號不同時段流量集合

*/

//定義計數(shù)器

long upPackNum = 0L;

long downPackNum = 0L;

long upPayLoad = 0L;

long downPayLoad = 0L;

//遍歷合并數(shù)據(jù)

for(KpiWritable kpi : v2s){

upPackNum += kpi.upPackNum;

downPackNum += kpi.downPackNum;

upPayLoad += kpi.upPayLoad;

downPayLoad += kpi.downPayLoad;

}

//封裝到對象中

KpiWritable v3 = new KpiWritable(upPackNum+"", downPackNum+"", upPayLoad+"", downPayLoad+"");

//寫入context中

context.write(k2, v3);

}

}

4、寫驅(qū)動程序

static final String INPUT_PATH = "hdfs://h1:9000/wlan";

static final String OUT_PATH = "hdfs://h1:9000/wlan_out";

public static void main(String[] args) throws Exception {

Configuration conf = new Configuration();

FileSystem fileSystem = FileSystem.get(new URI("hdfs://h1:9000/"), conf);

Path outPut = new Path(OUT_PATH);

if(fileSystem.exists(outPut)){

fileSystem.delete(outPut,true);

}

/**

* 1.1、指定輸入文件路徑

* 1.1.1. 指定那個類來格式化輸入文

* 1.2、指定自定義的Mapper類

* 1.2.1.指定輸出<k2,v2>的類型

* 1.3、指定分區(qū)

* 1.4、排序分區(qū)(TODO)

* 1.5、(可選)合并

* 2.1、多個map任務(wù)的輸出,通過網(wǎng)絡(luò)copy到不同的reduce節(jié)點(diǎn)上,這個操作由hadoop自動完成

* 2.2、指定定義的reduce類

* 2.2.1.指定輸出<k3,v3>類型

* 2.3、指定輸出位置

* 2.3.1、設(shè)置輸出文件的格式化類

*

* 最后吧代碼提交到JobTracker執(zhí)行

*/

//創(chuàng)建Job任務(wù)

Job job = new Job(conf,KpiApp.class.getSimpleName());

//設(shè)置輸入路徑

FileInputFormat.setInputPaths(job, INPUT_PATH);

//設(shè)置輸入數(shù)據(jù)使用的格式化類

job.setInputFormatClass(TextInputFormat.class);

//設(shè)置自定義Map類

job.setMapperClass(MyMapper.class);

//設(shè)置Map類輸出的key和value值類型

job.setMapOutputKeyClass(Text.class);

job.setMapOutputValueClass(KpiWritable.class);

//設(shè)置分區(qū)類

job.setPartitionerClass(HashPartitioner.class);

//設(shè)置任務(wù)數(shù)

job.setNumReduceTasks(1);

//設(shè)置自定義Reduce類

job.setReducerClass(MyReduce.class);

//設(shè)置輸入數(shù)據(jù)使用的格式化類

job.setInputFormatClass(TextInputFormat.class);

//設(shè)置Reduce輸出的key和value值類型

job.setMapOutputKeyClass(Text.class);

job.setMapOutputValueClass(KpiWritable.class);

//設(shè)置輸出文件位置

FileOutputFormat.setOutputPath(job, outPut);

//設(shè)置將任務(wù)提交到JobTracker

job.waitForCompletion(true);

}

MapReduce 0.x API區(qū)別

hadoop版本0.x

1、包一般是mapred。

2、使用是JobConf類創(chuàng)建Job任務(wù)。

3、使用JobClient.runJob(jobConf)提交任務(wù)。

4、自定義類需要繼承MapReduceBase實(shí)現(xiàn)Mapper和Reducer接口。

hadoop版本1.x

1、包一般是mapreduce。

2、使用的Job類創(chuàng)建任務(wù)。

3、ob.waitForCompletion(true)提交任務(wù)。

4、自定義類只需要繼承Mapper和Reducer類。

命令行運(yùn)行指定參數(shù)

hadoop jar WordCount.jar hdfs://h1:9000/hello hdfs://h1:9000/cmd_out

跟eclipse直接運(yùn)行的代碼區(qū)別:

1、類需要繼承org.apache.hadoop.conf.Configured,并實(shí)現(xiàn)org.apache.hadoop.util.Tool。

2、以前main方法中寫的驅(qū)動程序卸載覆寫的run方法中。
3、run()方法中

job.setJarByClass(CmdWordCount.class);

4、輸入輸出字符串定義為全局空字符串

5、main方法中使用org.apache.hadoop.util.ToolRunner的run方法,傳入new CmdWordCount()和args。args是main方法接收的字符串?dāng)?shù)組。

6、在覆寫的run方法中把接收到的args數(shù)組提取并賦值給INPUT和OUTPUT的路徑

INPUT_PATH = agrs0[0];

OUTPUT_PATH = args0[1];

6、打包時一定要記得選擇輸出類。

Hadoop計數(shù)器

File Input Format Counters

Bytes Read=19 讀取文件字節(jié)數(shù)

Map-Reduce Framework

Map output materialized bytes=65

1#Map input records=2 讀取記錄行

Reduce shuffle bytes=65

Spilled Records=8

Map output bytes=51

Total committed heap usage (bytes)=115675136

5#Combine input records=0 Map合并/規(guī)約輸入

SPLIT_RAW_BYTES=85

3# Reduce input records=4 reduce輸入行

4#Reduce input groups=3 Reduce輸入組數(shù)

Combine output records=0 Map合并/規(guī)約輸出

Reduce output records=3 Reduce輸出記錄

2#Map output records=4 Map輸出行

通過計數(shù)器數(shù)可以檢查出Map還是Reduce出現(xiàn)問題。

輿情監(jiān)督示例,使用自定義計數(shù)器監(jiān)控出現(xiàn)次數(shù)。

//自定義計數(shù)器

Counter helloCounter = context.getCounter("Sensitive Words", "hello");

String line = v1.toString();

if(line.contains("hello")){

helloCounter.increment(1L);

}

Combine操作

為什么使用Combine?

Combiner發(fā)生在Map端。對數(shù)據(jù)進(jìn)行規(guī)約處理,數(shù)據(jù)量變小了,傳送到reduce的數(shù)據(jù)量變小,傳輸時間變短,作業(yè)整體時間變短。

為什么Combine不作為MapReduce的標(biāo)配,而是可選配置?

因?yàn)椴皇撬械乃惴ǘ歼m合使用Combine處理,例如求平均數(shù)。

適用于求和

Combine本身已經(jīng)執(zhí)行了Reduce操作,為什么Reduce階段還要執(zhí)行reduce操作?

combine操作發(fā)送在map端,處理一個任務(wù)所接收的文件中的數(shù)據(jù),不能跨map任務(wù);只有reduce可以接收多個map任務(wù)處理數(shù)據(jù)。

設(shè)置參數(shù)

job.setCombinerClass(MyCombiner.class);

MyCombiner.class可以使用Reduce

Partitioner編程

對輸出的key,value進(jìn)行分區(qū)。

指定自定義partition類,自定義類需要繼承HashPartitioner類。覆蓋getPartition方法。

分區(qū)的實(shí)例必須打成Jar包。

作用:

1、根據(jù)業(yè)務(wù)需要,產(chǎn)生多個輸出文件。

2、多個reduce任務(wù)在運(yùn)行,提高整體job的運(yùn)行效率。

根據(jù)實(shí)際情況來使用,如果有5臺機(jī)器,而分成100個分區(qū)來運(yùn)行或出現(xiàn)延遲和整體效率低問題。因?yàn)樾枰抨犨\(yùn)行!

主要代碼:

設(shè)置成打包運(yùn)行 job.setJarByClass(KpiApp.class);

設(shè)置分區(qū)job.setPartitionerClass(MyPartitioner.class);

設(shè)置Reduce任務(wù)數(shù) job.setNumReduceTask(2);

自定義Partitioner類需要繼承HashPartition類,泛型使用K2,V2的類型。覆寫getPartition方法。

排序和分組

排序

在map和reduce階段進(jìn)行排序時,比較的是k2。v2是不參與排序比較。如果讓v2也進(jìn)行排序,需要將k2和v2組裝成心的類,作為k2,才能參與比較。

新類需要實(shí)現(xiàn)WritableCompareble,覆寫readFilds、write、compareTo、hasCode、equals方法。

在自定義map程序中將k2,v2封裝到新類中,當(dāng)做k2寫入context。

編寫驅(qū)動main方法時,設(shè)置map輸出的類型(job.setMapOutputKeyClass(new.class))

分組

按照K2進(jìn)行比較,這個k2是分裝到自定義類的k2。

自定義分組類實(shí)現(xiàn)RewComparetor,覆寫compare方法。

public int compare(NewK2 o1, NewK2 o2) {

return (int) (o1.k2 - o2.k2);

}

/**

* @param b1 表示第一個參與比較的字節(jié)數(shù)組

* @param s1 表示第一個參與比較的字節(jié)數(shù)組的起始位置

* @param l1 表示第一個參與比較的字節(jié)數(shù)組的偏移量

*

* @param b2 表示第二個參與比較的字節(jié)數(shù)組

* @param s2 表示第二個參與比較的字節(jié)數(shù)組的起始位置

* @param l2 表示第二個參與比較的字節(jié)數(shù)組的偏移量

*

*/

public int compare(byte[] b1, int s1, int l1, byte[] b2, int s2,

int l2) {

return WritableComparator.compareBytes(b1, s1, 8, b2, s2, 8);

}

job任務(wù)設(shè)置分組比較組 job.setGroupComparatorClass(MyGroup.class);

Shuffle

MapReduce的核心,俗稱洗牌、打亂。

shuffle在map任務(wù)傳送到reduce任務(wù)之間。

Map端

1、每個map有一個環(huán)形內(nèi)存緩沖區(qū),用于存儲任務(wù)的輸出,默認(rèn)100MB,如果達(dá)到法制80MB后臺線程會把內(nèi)容寫到指定磁盤(mapred.local.dir)下的新建的溢出文件。

2、寫入磁盤錢,要partition、sort。如果有combiner,combine后寫入。

3、最后記錄完成,合并全部溢寫文件為一個分區(qū)且排序的文件。

Reduce端

1、Reduce通過Http方式得到輸出文件的分區(qū)。

2、TaskTracker為分區(qū)文件運(yùn)行Reduce任務(wù)。復(fù)制階段把Map輸出復(fù)制到Reducer的內(nèi)存或磁盤。一個Map任務(wù)完成,Reduce開始復(fù)制輸出。

3、排序階段合并map輸出,最后運(yùn)行Reduce階段。

MapReduce常見算法

單詞計數(shù)

數(shù)據(jù)去重

排序

TopK

選擇

投影

分組

多表連接

單邊關(guān)聯(lián)

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

與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖

總結(jié)

以上是生活随笔為你收集整理的Hadoop学习记录(4)|MapReduce原理|API操作使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

亚洲综合网站在线观看 | 色夜影院 | 国产精品va最新国产精品视频 | 97麻豆视频 | 黄a在线 | 香蕉精品视频在线观看 | 久草精品在线 | 麻豆传媒视频在线播放 | 国产一区在线精品 | 日本h在线播放 | 国产一级二级在线观看 | 一区二区亚洲精品 | 综合久久一本 | 97在线看 | 久久久久久久久久网 | 97超在线 | 精品不卡av| av免费观看在线 | 日韩一区精品 | 91污在线| 激情综合国产 | 亚洲黄色片一级 | 中文字幕日本特黄aa毛片 | 婷婷色5月| 欧美日韩中文在线观看 | 婷婷中文字幕 | 日韩欧美精品在线观看视频 | 狠狠干2018 | 国产小视频在线观看 | 99国产精品久久久久老师 | 久久精品国产第一区二区三区 | www.夜夜夜| 日韩av一区二区在线播放 | 日韩欧美综合在线视频 | www.狠狠操.com | 综合色婷婷 | 婷婷激情综合五月天 | 欧美亚洲免费在线一区 | 国产美女免费看 | 欧美精品久久久久久 | 久久高清免费视频 | 免费观看全黄做爰大片国产 | 在线视频免费观看 | 国内小视频在线观看 | 欧美精品在线观看 | 国产免费一区二区三区最新 | 深爱五月激情网 | 国产一二区免费视频 | 五月婷婷黄色 | 欧美精品久久久久久久久免 | 亚洲精品视频免费在线 | 亚洲精品xx | 日韩 在线观看 | 99国产精品免费网站 | 久久亚洲影院 | 国产在线更新 | 成人资源站| 免费日韩在线 | 久久精品欧美日韩精品 | 欧美极品xxxxx| 欧美在线不卡一区 | 亚洲精品视频免费在线观看 | 精品一区二区综合 | 丁香六月激情 | 国产老太婆免费交性大片 | 久久精品精品 | 亚洲欧美视频一区二区三区 | 在线观看免费色 | 91精品国产乱码在线观看 | 一区二区三区免费在线观看 | 亚洲高清在线 | 六月丁香综合网 | 天天干,狠狠干 | 中文字幕 国产专区 | 欧美一区二区三区在线观看 | 97在线观看免费 | 最近中文字幕 | 日日夜夜狠狠干 | www.综合网.com | 欧美日韩性| 麻豆免费视频观看 | 中文字幕电影一区 | 天天天干夜夜夜操 | 免费国产在线精品 | 激情av综合| 久久高清免费 | 天天干夜夜想 | 97超碰资源总站 | 欧美日韩在线观看一区二区三区 | 视频在线一区二区三区 | 在线看成人 | 天天透天天插 | 青青河边草观看完整版高清 | 综合网天天色 | 涩涩资源网 | 亚洲一级黄色 | 中文字幕亚洲欧美日韩 | 91成人在线视频观看 | av888.com | 国产无吗一区二区三区在线欢 | 国产美女网站在线观看 | 天天射成人| 高清不卡一区二区三区 | 亚洲婷婷丁香 | 456免费视频| 成 人 黄 色 视频 免费观看 | 免费观看的av网站 | 成人黄色小说在线观看 | 91传媒免费在线观看 | 999热视频| 亚洲va欧洲va国产va不卡 | 久久99精品国产91久久来源 | 婷婷网在线 | 香蕉久久久久久av成人 | 成人午夜黄色 | 婷婷六月天天 | 色www免费视频 | 久久一区二区三区四区 | 狠狠色免费 | 国产精品久久久久久久久久久久 | 国产麻豆精品一区 | 中国一级片在线观看 | 国产小视频免费在线观看 | 国产高潮久久 | 香蕉网址| 欧美日韩中文在线视频 | 伊人网站 | 国产精品久久久毛片 | 日日操操操 | 超碰在线观看97 | 久久久高清一区二区三区 | 黄色av影院 | 日韩亚洲国产精品 | 亚洲欧美日韩精品久久久 | 国产小视频你懂的在线 | 国产精品久久久久久电影 | 日韩av成人免费看 | 亚洲国产视频a | 黄色av电影在线 | 天天操天天操天天操天天操天天操天天操 | 欧美成年网站 | 日韩成人高清在线 | 悠悠av资源片 | 国产精品久免费的黄网站 | 国产成人精品999 | 亚洲区视频在线观看 | 99久久精品免费一区 | 免费色视频在线 | 一区二区视频免费在线观看 | 国产精品情侣视频 | 日韩精品电影在线播放 | 国产xxxx性hd极品 | 最新av网址大全 | 久久久久免费网站 | 亚洲精品福利在线 | 免费男女网站 | 中文字幕永久在线 | 国产高清福利在线 | 国产视频一区二区在线 | 国产视频 久久久 | 西西444www大胆无视频 | www.黄色| 黄色国产在线观看 | 97国产超碰在线 | 亚洲黄色在线 | 亚洲电影自拍 | 亚洲成人动漫在线观看 | 成人久久18免费网站 | 久久爽久久爽久久av东京爽 | 麻豆国产在线播放 | 成年人免费看 | 天天操狠狠操夜夜操 | 又爽又黄又刺激的视频 | 日日干天天操 | 在线播放国产一区二区三区 | 亚洲精品视频在线观看免费视频 | 国产精品 国内视频 | 91热爆视频 | 91亚洲在线观看 | 久操中文字幕在线观看 | 欧美午夜性生活 | 国产一区二区三精品久久久无广告 | 中文字幕在线观看免费高清电影 | 精品国产伦一区二区三区观看体验 | 97人人澡人人爽人人模亚洲 | 日韩av不卡在线播放 | av福利资源 | 免费观看国产成人 | 亚洲精品色婷婷 | 99久久久久久久久 | 亚洲aⅴ一区二区三区 | 91精品在线免费观看视频 | 91成人精品一区在线播放 | 免费a级黄色毛片 | 夜夜操网站 | 国产特级毛片 | av在线com| 亚洲免费av在线播放 | 成人黄色小说网 | 99精品偷拍视频一区二区三区 | 国产精品综合久久 | 伊人夜夜 | 超碰人人超碰 | 最新av网址在线观看 | 毛片.com| 福利片视频区 | 欧美成人性网 | 伊人av综合 | 国产亚洲综合性久久久影院 | 久久婷婷国产色一区二区三区 | av短片在线 | 久草在线视频首页 | 97成人在线免费视频 | 国产专区在线视频 | 狠狠色噜噜狠狠 | 99re热精品视频 | 中文字幕精品视频 | 91桃色在线观看视频 | 九九爱免费视频 | 黄色小视频在线观看免费 | 国产中文字幕三区 | 97人人视频 | 精品久久在线 | 免费在线播放黄色 | 亚洲成年人av | 亚洲 欧洲 国产 日本 综合 | 久久一区二区三区国产精品 | 亚洲黄色影院 | 日韩久久精品一区二区三区下载 | 久久视屏网 | 欧美国产日韩久久 | 婷婷久久一区 | 国产一级特黄毛片在线毛片 | 特黄色大片| 免费在线观看黄网站 | 亚洲 欧洲 国产 日本 综合 | 国产精品高清在线 | 热99在线 | 蜜桃视频成人在线观看 | 瑞典xxxx性hd极品 | 香蕉视频18 | 九九热国产 | 国产精品123| 综合五月 | wwxxxx日本 | 婷婷丁香狠狠爱 | 欧美日韩高清一区二区 | 亚洲国产网址 | 国产伦理一区 | 国产精品麻豆欧美日韩ww | 久久伊人八月婷婷综合激情 | 超碰在线人人爱 | 片黄色毛片黄色毛片 | 成年人在线免费看片 | 在线国产欧美 | 久久不见久久见免费影院 | 亚洲精品免费在线观看 | 国产福利免费在线观看 | 99爱在线 | 国产成人精品一区二区三区在线观看 | 国产高清绿奴videos | 亚洲欧美日本一区二区三区 | 国产日韩精品一区二区三区 | 免费黄色在线网址 | 亚洲国产播放 | 国产视频色 | 国产精品18久久久久久久 | 激情五月综合网 | 国产一区在线观看免费 | 欧美一二三在线 | 久久久久在线观看 | 国产视频一级 | 国产精品自拍在线 | 97色在线观看免费视频 | 在线视频app | 国产精品久久精品国产 | 成人黄色在线播放 | 日韩精品一区在线播放 | 波多野结衣电影一区二区三区 | 欧美激情xxxx性bbbb | www五月婷婷 | 久在线观看视频 | 在线观看免费视频 | 九九视频在线观看视频6 | 免费观看av网站 | 日韩有码在线观看视频 | 免费污片 | 国产精品va | 国产精品二区在线观看 | 黄色片免费电影 | 制服丝袜成人在线 | 久久精品91久久久久久再现 | 青青河边草观看完整版高清 | 成人av手机在线 | 美女性爽视频国产免费app | 久久黄色影视 | 久久久午夜精品福利内容 | 黄色app网站在线观看 | 五月婷亚洲| 久久精品亚洲精品国产欧美 | 久久一二三四 | 成人黄色电影视频 | 亚洲欧美日韩一区二区三区在线观看 | 成人高清在线观看 | 久久夜色精品国产欧美乱极品 | 国产精品热| 综合网伊人 | 国产在线视频在线观看 | 国产精品久久久久久久免费大片 | 欧美成人999 | 狠狠干中文字幕 | 在线中文字幕视频 | 韩国av一区二区三区 | 国产美女网站视频 | 欧美另类v| 国产99久久久精品 | 制服丝袜在线91 | 欧美日韩国产精品一区二区亚洲 | 怡春院av| 国产精品久久麻豆 | 国产精品一区二区三区免费看 | 欧美精品在线观看免费 | 国产免费人人看 | 在线免费精品视频 | 久艹在线观看视频 | 成人在线视频你懂的 | 少妇性bbb搡bbb爽爽爽欧美 | 狠狠操在线 | 在线视频观看91 | 99999精品视频 | 久久调教视频 | 99精品国产免费久久久久久下载 | 日一日操一操 | 国产精品久久一区二区三区不卡 | 国产韩国精品一区二区三区 | 免费看麻豆 | 日韩av中文字幕在线 | 美女av免费看 | 中文字幕在线看视频国产中文版 | 日韩影视在线 | 国产日韩视频在线观看 | 久久视频免费在线观看 | 欧美精品在线一区 | 亚洲天堂精品视频 | 五月天久久综合网 | 精品在线亚洲视频 | 天天操操操操操 | 黄色大片中国 | 久久在线精品 | 亚洲日本韩国一区二区 | 精品国模一区二区三区 | 久久电影中文字幕视频 | 欧美性猛片, | 五月天中文在线 | 免费高清在线观看成人 | 免费在线黄色av | 六月丁香婷婷网 | 亚洲成a人片综合在线 | 精品久久久国产 | 999久久久久久 | 免费久久99精品国产婷婷六月 | 国产在线污 | 国产黄色大片 | 在线a人片免费观看视频 | 日韩午夜电影网 | 免费日韩 精品中文字幕视频在线 | av韩国在线| 久久中文字幕导航 | 日韩av中文在线 | 精品一区二区免费 | 超碰在线色 | 午夜性生活片 | .精品久久久麻豆国产精品 亚洲va欧美 | 中文字幕不卡在线88 | 中文字幕 二区 | 国产成人精品久久二区二区 | 在线免费高清一区二区三区 | 天天操天天综合网 | 一级特黄av | 五月天网站在线 | 黄色毛片电影 | 在线看小早川怜子av | 国产探花| 久久国产高清视频 | 深爱五月激情五月 | 色在线最新 | 精品国产一区二区三区蜜臀 | 国产午夜三级一区二区三桃花影视 | 日韩电影在线观看中文字幕 | 日韩av一区二区三区 | 国产精品成人久久久久 | 中文字幕在线网址 | 精品视频在线播放 | 亚洲精品无 | 国产精品视频999 | 久久五月情影视 | 日韩欧美在线观看 | 久久男女视频 | 黄色成品视频 | 精品国产午夜 | 五月婷婷视频在线 | 人人插人人玩 | 在线观看色网 | av 一区二区三区 | 成人免费视频播放 | 久久婷婷五月综合色丁香 | 国产视频久久久 | 国产精品美女毛片真酒店 | 91精品视频一区二区三区 | 中文字幕在线播放日韩 | 六月婷婷网 | 亚洲综合婷婷 | 中文综合在线 | 在线观看国产福利片 | 啪啪免费视频网站 | 天天草天天草 | 国产97在线观看 | 99精品热视频只有精品10 | 国产在线观看你懂的 | 久久精品国产第一区二区三区 | 久久久久久国产精品999 | 九色最新网址 | 免费福利在线 | 精品国产美女 | 国产一区视频在线观看免费 | 欧美成人区 | 亚洲精品www. | 日韩欧美高清视频在线观看 | 五月天色网站 | 国产一区二区高清不卡 | 中文字幕第一页在线播放 | 国产在线视频资源 | 三级黄色欧美 | 操操碰 | 精品伊人久久久 | 中文字幕乱码亚洲精品一区 | 久久久亚洲精品 | 国产精品 视频 | 午夜电影一区 | 欧美日韩一级在线 | 亚洲精品视频在线观看网站 | 国产精品一区二区果冻传媒 | 激情深爱.com| 国产精品婷婷午夜在线观看 | 成人午夜久久 | 亚洲黄色免费电影 | 丁香五月网久久综合 | 91亚洲欧美激情 | 中文字幕中文字幕在线中文字幕三区 | 成年人国产视频 | 国产精品igao视频网入口 | 国产成人精品亚洲a | 亚洲精品国产综合久久 | 欧美成人性战久久 | 国产视频一区二区三区在线 | 色老板在线视频 | 日韩欧美一区二区三区在线观看 | 黄色免费高清视频 | www黄色大片 | 亚洲视频在线播放 | 精品日韩在线一区 | av电影在线观看完整版一区二区 | 久久久91精品国产 | 99热精品久久 | 一区二区成人国产精品 | 91人网站 | 国产一区二区免费 | 五月天狠狠操 | 久热这里有精品 | 久久久久免费精品 | 99久久影院| 国产黄色在线观看 | 日本高清中文字幕有码在线 | 国产99精品 | 一区二区三区福利 | 色九九视频 | 国产成人61精品免费看片 | 国产中文字幕在线 | 五月婷婷丁香在线观看 | 亚洲精品乱码白浆高清久久久久久 | 日韩一区正在播放 | 成人理论在线观看 | 久久黄色a级片 | 久久久久国产成人精品亚洲午夜 | 免费看黄在线看 | 国产精品v a免费视频 | 999精品 | 久久久久一区二区三区四区 | 349k.cc看片app | 亚洲天天综合网 | 国产97色在线 | 亚洲一级黄色 | www日韩| 国产精品永久在线 | 久久精品日韩 | 中文在线8新资源库 | 日韩亚洲国产中文字幕 | 349k.cc看片app| 国产成人综合在线观看 | 日本黄网站 | 亚洲黄色免费网站 | 久久精品99国产精品日本 | 久久国产区 | 永久免费在线 | 日韩免费 | 狠狠做深爱婷婷综合一区 | 亚洲精品一区二区精华 | 久久av福利 | 一区av在线播放 | 日韩黄色软件 | 亚洲久草在线视频 | 国产精品theporn | 最新日韩在线观看 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 97在线成人 | 国产91综合一区在线观看 | 天天天干天天天操 | 亚洲自拍自偷 | 激情综合亚洲 | 色视频国产直接看 | 五月黄色 | av免费网站在线观看 | 在线观看91网站 | 黄色在线观看网站 | 日韩欧美99 | 色欧美88888久久久久久影院 | 日日干夜夜爱 | 97精品国产97久久久久久春色 | 欧美国产三区 | a在线免费 | 少妇自拍av | 久久国产精品99久久久久久丝袜 | 免费网站污 | 中文在线免费一区三区 | 日本黄色大片免费 | 深爱激情五月网 | 久草亚洲视频 | 久久午夜免费观看 | 亚洲va天堂va欧美ⅴa在线 | 国产成人精品久久亚洲高清不卡 | 亚洲综合一区二区精品导航 | 在线观看一级视频 | 日韩欧美国产激情在线播放 | 97日日碰人人模人人澡分享吧 | 国产成a人亚洲精v品在线观看 | 婷婷伊人综合亚洲综合网 | 91九色在线视频 | 色资源网在线观看 | 黄色一集片 | 久久精品国产v日韩v亚洲 | 国产成人久久精品亚洲 | 久99久视频 | 国产小视频在线观看免费 | 99国产在线观看 | 国产高清在线免费观看 | 欧美地下肉体性派对 | 日韩字幕在线 | 欧美狠狠色 | 天天爱综合| 日韩av高清| 欧美一区二区三区不卡 | 亚洲3级| 四虎影视成人精品国库在线观看 | 精品一区二区6 | 久久久久久国产精品亚洲78 | 久久久国产精华液 | 国产97碰免费视频 | 在线免费性生活片 | 国产网红在线观看 | 国产免费一区二区三区网站免费 | 99综合视频 | 日韩欧美电影 | 最新成人在线 | 9999毛片 | 日韩| 成年人视频在线免费观看 | 国产精品片 | av中文字幕av| 五月婷婷六月丁香在线观看 | av福利在线看| 国内精品久久久久久久久 | 欧美综合在线观看 | 又黄又刺激又爽的视频 | 日韩网站视频 | 麻豆国产精品va在线观看不卡 | 成人高清在线 | 国产精品久久av | 激情五月色播五月 | 美女网站在线免费观看 | 国产在线观看你懂的 | 国产视频1| 日韩色视频在线观看 | 蜜桃久久久 | 成人亚洲精品国产www | 国产欧美日韩一区 | 久久精品一二三区 | 免费看黄色小说的网站 | 制服丝袜天堂 | 久久免费视频一区 | 久久久久久久久久久网站 | 日韩亚洲国产中文字幕 | 欧美不卡视频在线 | 国产在线毛片 | 国产另类av | 国产午夜精品一区二区三区在线观看 | 色片网站在线观看 | 狠狠操夜夜| 久久视奸 | 天天天干天天天操 | 香蕉网站在线观看 | 日韩在线第一 | 精品在线观看视频 | 色婷婷狠狠五月综合天色拍 | 欧美日韩在线观看一区二区 | 午夜国产福利在线 | 蜜桃av人人夜夜澡人人爽 | 国产美女精品视频免费观看 | 天天躁日日躁狠狠躁av中文 | 国产精品11 | 国产黄色在线 | 国产欧美精品xxxx另类 | 久久极品 | 五月激情亚洲 | 亚洲韩国一区二区三区 | 日操干 | 国产午夜精品一区二区三区四区 | 最新真实国产在线视频 | 国产在线看一区 | 日韩av在线免费看 | 99国产精品免费网站 | 亚洲欧洲国产精品 | 久久久精品午夜 | 欧美日比视频 | 天天摸日日摸人人看 | 天天综合网久久 | 欧美成人一区二区 | 四虎成人精品在永久免费 | 婷婷色 亚洲 | 中文在线www | 在线看v片 | 香蕉视频在线观看免费 | 免费看黄色小说的网站 | 韩国视频一区二区三区 | 国产精品免费久久久久久久久久中文 | 亚洲激情综合 | av一级免费 | 狠狠的日| 国产a免费 | 91成人在线观看喷潮 | 久久综合色播五月 | 国产麻豆精品传媒av国产下载 | 天天艹天天 | 国产精品二区三区 | 日韩高清片 | 中文字幕观看av | 国产亚洲精品美女 | 黄色影院在线观看 | 伊人电影在线观看 | 91成人午夜 | 日韩精品免费一线在线观看 | 亚洲成熟女人毛片在线 | 午夜 久久 tv | 亚洲在线 | 亚洲作爱 | 国产精品一区二区在线免费观看 | 中文字幕91 | 国产精品久久久久aaaa九色 | 99视频国产精品免费观看 | 久久综合婷婷 | 成人黄色中文字幕 | 色综合天天天天做夜夜夜夜做 | 天天躁日日躁狠狠躁av中文 | 午夜国产一区二区 | 久久黄色精品视频 | 激情久久一区二区三区 | 久久女同性恋中文字幕 | 97热在线观看 | 亚洲成免费 | 亚洲日本va午夜在线电影 | 在线视频精品播放 | 免费视频97 | 久草在线一免费新视频 | 国产在线1区 | 99视频精品视频高清免费 | 亚洲精品456在线播放 | 一区二区中文字幕在线观看 | 精品在线观看国产 | 日本h在线播放 | 香蕉视频在线播放 | av在线播放快速免费阴 | 夜夜骑日日| 国产成人99av超碰超爽 | 日本久久91 | 欧美日韩在线免费视频 | 久久久久久久久久影视 | 97成人在线免费视频 | 色九九视频 | 日韩精品一区二区三区在线视频 | 色婷婷国产精品 | 手机成人av| 精品亚洲男同gayvideo网站 | 亚洲欧美精品一区二区 | 亚洲国产视频直播 | 99产精品成人啪免费网站 | 久久艹在线观看 | 国产在线精品一区二区三区 | 欧美在线视频一区二区三区 | 国产精品手机在线观看 | 夜夜躁日日躁狠狠久久88av | 日韩激情av在线 | 国产精品大片免费观看 | 91天堂影院| 亚洲精品乱码久久久久 | 国产高清视频在线 | 精品久久久久_ | 波多野结衣电影一区二区三区 | 欧美黑人巨大xxxxx | 青青看片 | 深夜福利视频一区二区 | 国产精品久久99精品毛片三a | 久久福利综合 | 精品影院| 麻豆一区二区三区视频 | 欧美福利片在线观看 | 怡红院成人在线 | 欧美色综合天天久久综合精品 | 日韩av一区二区三区四区 | 91日韩在线播放 | 亚洲精品欧洲精品 | 国产成人精品一区二区三区网站观看 | 久草网免费| 国产精品久久久久aaaa | 国产日韩欧美在线观看视频 | 欧美国产日韩久久 | 久久久在线视频 | 久久精品站 | 又黄又爽又刺激的视频 | 久久欧美综合 | 久久99久久久久久 | 欧美 激情在线 | 91探花视频 | 亚洲成 人精品 | 亚洲精品久久久久中文字幕二区 | 国产高清不卡av | 国产成人高清av | 黄污视频网站 | 久久这里只有精品23 | 天天操天天干天天玩 | 久久影视网 | 特级毛片aaa | 日韩无在线 | 精品国产大片 | 一区二区视频播放 | 日韩黄色在线观看 | 国产精品大片在线观看 | 九色视频网站 | 成人福利在线播放 | 91麻豆视频 | 久久视频中文字幕 | 九九九九热精品免费视频点播观看 | 青青河边草观看完整版高清 | 91在线中文字幕 | 日本爱爱片 | 91麻豆精品国产91久久久更新时间 | 黄色毛片观看 | 在线视频 精品 | 久久国产精品成人免费浪潮 | 亚洲91中文字幕无线码三区 | 欧美一级黄色网 | 丁香婷婷深情五月亚洲 | 福利视频一区二区 | 久久1电影院 | 色婷婷综合久久久久中文字幕1 | 夜夜干夜夜 | 91大神免费视频 | 福利av影院 | 久久精品视频在线免费观看 | 国产精品6| 亚洲激情一区二区三区 | 国产亚洲成人网 | 久久精品999 | 亚洲精品视频免费 | 国产综合久久 | 丁香九月激情 | 亚在线播放中文视频 | 在线观看黄色小视频 | 日韩黄在线观看 | 高潮久久久久久 | 久久精品这里精品 | 九九视频这里只有精品 | 亚洲精品视频在线观看免费 | 欧美日韩一区二区在线 | 久久久精品成人 | 亚洲欧美日韩一级 | 欧美孕妇与黑人孕交 | 欧美日本高清视频 | 久久成人国产精品 | 日本亚洲国产 | 五月婷婷综合激情网 | 成人av影院在线观看 | 一区二区 不卡 | 黄色视屏av | 激情五月婷婷网 | 蜜桃视频精品 | 日韩av电影中文字幕 | 日本深夜福利视频 | 爱爱av网站| 久久国产日韩 | 91成人看片| 日韩视频欧美视频 | 日日操日日干 | 成年人网站免费在线观看 | 国产xxxxx在线观看 | av电影中文字幕在线观看 | 国产精品一区在线 | 69av国产 | 天天拍天天操 | 成人在线免费看视频 | 黄色小视频在线观看免费 | 二区精品视频 | 国产成人a亚洲精品 | 欧美日韩性 | av免费电影网站 | 91看片在线| 国产精品va在线观看入 | 日韩视频免费在线观看 | 欧美日韩精品在线 | 免费在线观看视频a | 五月花激情 | 九九视频免费 | 国产精品剧情 | 久久久999| 69人人 | 国产精品美女视频网站 | 中文字幕在线中文 | 在线看国产精品 | 91麻豆福利 | 国产成人三级三级三级97 | 国产成人三级在线观看 | 天天插天天狠 | 啪啪小视频网站 | 黄色软件在线观看视频 | av电影在线观看 | 欧美日韩观看 | 国产一线二线三线性视频 | 日韩在线免费播放 | 99在线观看视频 | 欧美久久久久久久 | 中文日韩在线视频 | 四虎最新入口 | 久久69av | 在线观看中文字幕一区 | 午夜12点| 天天拍天天操 | 久久精品5| 在线观看视频亚洲 | 久久久久久国产精品999 | 日韩欧美一区二区三区免费观看 | 国产91对白在线播 | 国产毛片久久久 | 九色激情网 | 999久久久久久久久久久 | 亚洲va欧美va人人爽 | 精品女同一区二区三区在线观看 | 国产精品综合av一区二区国产馆 | 国产字幕在线看 | 日本韩国精品在线 | 正在播放一区 | 国产精品久久久久久久久费观看 | 在线亚州 | 国产一区二区在线视频观看 | 久久精品久久久久久久 | 久久精品久久精品久久精品 | 99视频在线精品免费观看2 | 狠狠色丁香婷婷 | 国产一级电影 | 精品一区在线看 | 一级一片免费看 | 91久久人澡人人添人人爽欧美 | 亚洲视频电影在线 | 日韩电影久久久 | 国产黄av | 亚洲精品字幕在线观看 | 99精品在线观看 | 欧美日韩在线免费观看视频 | 日韩不卡高清视频 | 九九久久国产 | 视频国产精品 | 国产成人在线精品 | 国产精品女 | 亚洲精欧美一区二区精品 | 亚洲午夜精品一区二区三区电影院 | 午夜 在线 | 国产精品嫩草影视久久久 | 超碰在线94 | 99热国产在线观看 | 婷婷网五月天 | 成人黄色小说视频 | 午夜精品福利一区二区三区蜜桃 | 伊人成人激情 | 日本高清免费中文字幕 | 欧美黄色特级片 | 国产成人精品亚洲a | 久草在线官网 | 亚洲国内在线 | 在线免费观看国产黄色 | 中文字幕在线人 | 久久国产网站 | 日韩成人精品 | 欧美a在线免费观看 | 六月色丁| 精品一二三区视频 | 精品a级片| 久久久久久久久久久网站 | 国产一区二区久久 | 五月婷婷香蕉 | 97综合视频 | 久久精品国产精品亚洲 | www.黄色| 中文字幕日本特黄aa毛片 | 手机在线免费av | 婷婷综合亚洲 | av在线8| 欧美性受极品xxxx喷水 | 久久亚洲欧美日韩精品专区 | 青草草在线视频 | 国内精品久久久久久中文字幕 | 婷婷伊人综合 | 手机av在线网站 | 国产香蕉视频在线播放 | 国产香蕉97碰碰碰视频在线观看 | 国产精品成人一区二区三区 | 国产亚洲婷婷免费 | 久久国产精品99久久久久久老狼 | 国产片网站 | 久久涩涩网站 | 九九热视频在线播放 | 国内三级在线 | 久久精品免费看 | 国产日韩欧美精品在线观看 | 日韩激情影院 | 91丨九色丨91啦蝌蚪老版 | 综合天堂av久久久久久久 | 天天操操操操操 | 欧美另类69 | 亚洲国产成人久久综合 | 中文国产在线观看 | 天天综合网~永久入口 | 欧美色图p | 久草线| 激情丁香 | 91在线观看视频网站 | 亚洲天堂香蕉 | 国产一区二区三区免费在线 | 免费视频久久久 | www.久久久精品 | 国产日韩视频在线播放 | 五月婷婷av | 亚洲天堂网站 | 精品99久久久久久 | 国产亚洲情侣一区二区无 | 精品久久久久久电影 | 精品中文字幕在线观看 | 国产一区二区在线观看视频 | 精品美女视频 | 成人av在线直播 | av网站免费线看精品 | 国产精品欧美久久久久天天影视 | 精品国产成人 | 亚洲五月婷| 午夜色场| 中文在线天堂资源 | 亚洲在线不卡 | 在线视频 区 | 麻豆久久一区二区 | 人人狠狠| 欧美精品成人在线 | 国产精品一区二区三区在线播放 | 中文字幕亚洲欧美日韩 | 精品一二区 | 久久精品综合网 | 啪啪动态视频 | 亚洲精品动漫成人3d无尽在线 | 日韩99热| av不卡免费看| 日韩综合在线观看 | 香蕉视频在线免费看 | 久久一区二区三区国产精品 | 九九久久精品 | 97精品国产91久久久久久久 | 欧洲亚洲女同hd | 九九日九九操 | 亚洲视频播放 | 中文高清av | 涩涩资源网| 91理论片午午伦夜理片久久 | 日韩精品电影在线播放 | 日韩午夜av|