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

歡迎訪問(wèn) 生活随笔!

生活随笔

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

编程问答

WordCount作业提交到FileInputFormat类中split切分算法和host选择算法过程源码分析

發(fā)布時(shí)間:2024/6/30 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 WordCount作业提交到FileInputFormat类中split切分算法和host选择算法过程源码分析 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

參考?FileInputFormat類中split切分算法和host選擇算法介紹? 以及?Hadoop2.6.0的FileInputFormat的任務(wù)切分原理分析(即如何控制FileInputFormat的map任務(wù)數(shù)量)? 以及?Hadoop中FileInputFormat計(jì)算InputSplit的getSplits方法的流程? 以及?hadoop作業(yè)分片處理以及任務(wù)本地性分析(源碼分析第一篇)? ??

分析前先介紹一下:

( 這里要注意下, Block 的 hosts 和 Split 的 hosts 不一樣,?Split 的 hosts 是通過(guò) Split 的 hosts 按一定方法生成的, 如果一個(gè) Block 對(duì)應(yīng)一個(gè) Split (一般情況下是這樣的), 這時(shí)它們兩個(gè) hosts 是一樣的. 如果不是一對(duì)一( Split > block), 則 Split 需要按一定方法選擇 hosts .?

Split 和 MapTask 是一一對(duì)應(yīng)的, 一個(gè) Split 對(duì)應(yīng)一個(gè) MapTask. 所以本地性是跟 Split 的 hosts 相關(guān)的.

BlocksMap存儲(chǔ) Block 與 BlockInfo 的映射關(guān)系, Block 中主要包含3項(xiàng): long blockId;? // 數(shù)據(jù)塊的唯一標(biāo)識(shí),即數(shù)據(jù)塊的ID號(hào).?long numBytes;? // 數(shù)據(jù)塊包含的文件數(shù)據(jù)大小.?long generationStamp;? // 數(shù)據(jù)塊的版本號(hào),或數(shù)據(jù)塊的時(shí)間戳.? ?BlockInfo( 在 Hadoop-2.7.3 中是 BlockInfoContiguous) 包含所以副本所在主機(jī)名.? )

開(kāi)始分析: ( 這里是 hadoop-2.7.3-src )

以WordCount開(kāi)始:?org.apache.hadoop.examples.WordCount.main() 內(nèi)部調(diào)用?org.apache.hadoop.mapreduce.Job.waitForCompletion(boolean)

// 該段代碼在 org.apache.hadoop.examples.WordCountpublic static void main(String[] args) throws Exception {Configuration conf = new Configuration(); //指定作業(yè)執(zhí)行規(guī)范 , Configuration:map/reduce的j配置類,向hadoop框架描述map-reduce執(zhí)行的工作String[] otherArgs = new GenericOptionsParser(conf, args).getRemainingArgs();if (otherArgs.length < 2) {System.err.println("Usage: wordcount <in> [<in>...] <out>");System.exit(2);}Job job = Job.getInstance(conf, "word count"); //指定job名稱,及運(yùn)行對(duì)象 job.setJarByClass(WordCount.class);job.setMapperClass(TokenizerMapper.class); //為job設(shè)置Mapper類 job.setCombinerClass(IntSumReducer.class); //為job設(shè)置Combiner類 job.setReducerClass(IntSumReducer.class); //為job設(shè)置Reducer類job.setOutputKeyClass(Text.class); //為job的輸出數(shù)據(jù)設(shè)置Key類job.setOutputValueClass(IntWritable.class); //為job輸出設(shè)置value類 for (int i = 0; i < otherArgs.length - 1; ++i) {FileInputFormat.addInputPath(job, new Path(otherArgs[i])); //為job設(shè)置輸入路徑, org.apache.hadoop.mapreduce.lib.input.FileInputFormat }FileOutputFormat.setOutputPath(job,new Path(otherArgs[otherArgs.length - 1])); //為job設(shè)置輸出路徑 System.exit(job.waitForCompletion(true) ? 0 : 1); //運(yùn)行job, 調(diào)用 Job.waitForCompletion()} WordCount

在 Job.waitForCompletion() 函數(shù)內(nèi)部會(huì)調(diào)用 Job 本類的方法 submit(), 在?submit() 內(nèi)部接著調(diào)用?org.apache.hadoop.mapreduce.JobSubmitter.submitJobInternal(Job , Cluster)

// 該段代碼在 org.apache.hadoop.mapreduce.Job 中// ....../*** Submit the job to the cluster and wait for it to finish.* @param verbose print the progress to the user* @return true if the job succeeded* @throws IOException thrown if the communication with the * <code>JobTracker</code> is lost*/public boolean waitForCompletion(boolean verbose) throws IOException, InterruptedException,ClassNotFoundException {if (state == JobState.DEFINE) {submit(); // 調(diào)用本類的 submit() }if (verbose) {monitorAndPrintJob();} else {// get the completion poll interval from the client.int completionPollIntervalMillis = Job.getCompletionPollInterval(cluster.getConf());while (!isComplete()) {try {Thread.sleep(completionPollIntervalMillis);} catch (InterruptedException ie) {}}}return isSuccessful();}// ....../*** Submit the job to the cluster and return immediately.* @throws IOException*/public void submit() throws IOException, InterruptedException, ClassNotFoundException {ensureState(JobState.DEFINE);setUseNewAPI();connect();final JobSubmitter submitter = getJobSubmitter(cluster.getFileSystem(), cluster.getClient());status = ugi.doAs(new PrivilegedExceptionAction<JobStatus>() {public JobStatus run() throws IOException, InterruptedException, ClassNotFoundException {return submitter.submitJobInternal(Job.this, cluster); // }});state = JobState.RUNNING;LOG.info("The url to track the job: " + getTrackingURL());} Job

?在?JobSubmitter.submitJobInternal(Job , Cluster) 函數(shù)內(nèi)部調(diào)用本類的?writeSplits(Job ,Path )? 為job創(chuàng)建分片; 接著?writeSplits(Job ,Path?) 方法內(nèi)部會(huì)調(diào)用本類的 (1) writeNewSplits(JobContext , Path ) { Hadoop2.0 會(huì)調(diào)用這個(gè),新版的API}和 (2) writeOldSplits(JobConf , Path ) { 這個(gè)是舊版的 API };?在?JobSubmitter.writeNewSplits(JobContext , Path?) 方法內(nèi)部會(huì)調(diào)用抽象類?org.apache.hadoop.mapreduce.InputFormat.getSplites(JobContext ), 計(jì)算job的輸入文件的邏輯分片集合; 而在?JobSubmitter.writeOldSplits(JobContext , Path?) 方法內(nèi)部會(huì)調(diào)用抽象類?org.apache.hadoop.mapred.InputFormat.getSplites(JobContext , int ), 計(jì)算job的輸入文件的邏輯分片集合.

// 該段代碼在 org.apache.hadoop.mapreduce.JobSubmitter 中// ....../*** Internal method for submitting jobs to the system.* * <p>The job submission process involves:* <ol>* <li>* Checking the input and output specifications of the job.* </li>* <li>* Computing the {@link InputSplit}s for the job.* </li>* <li>* Setup the requisite accounting information for the * {@link DistributedCache} of the job, if necessary.* </li>* <li>* Copying the job's jar and configuration to the map-reduce system* directory on the distributed file-system. * </li>* <li>* Submitting the job to the <code>JobTracker</code> and optionally* monitoring it's status.* </li>* </ol></p>* @param job the configuration to submit* @param cluster the handle to the Cluster* @throws ClassNotFoundException* @throws InterruptedException* @throws IOException*/JobStatus submitJobInternal(Job job, Cluster cluster) throws ClassNotFoundException, InterruptedException, IOException {//validate the jobs output specs checkSpecs(job);Configuration conf = job.getConfiguration();addMRFrameworkToDistributedCache(conf);Path jobStagingArea = JobSubmissionFiles.getStagingDir(cluster, conf);//configure the command line options correctly on the submitting dfsInetAddress ip = InetAddress.getLocalHost();if (ip != null) {submitHostAddress = ip.getHostAddress();submitHostName = ip.getHostName();conf.set(MRJobConfig.JOB_SUBMITHOST,submitHostName);conf.set(MRJobConfig.JOB_SUBMITHOSTADDR,submitHostAddress);}JobID jobId = submitClient.getNewJobID();job.setJobID(jobId);Path submitJobDir = new Path(jobStagingArea, jobId.toString());JobStatus status = null;try {conf.set(MRJobConfig.USER_NAME,UserGroupInformation.getCurrentUser().getShortUserName());conf.set("hadoop.http.filter.initializers", "org.apache.hadoop.yarn.server.webproxy.amfilter.AmFilterInitializer");conf.set(MRJobConfig.MAPREDUCE_JOB_DIR, submitJobDir.toString());LOG.debug("Configuring job " + jobId + " with " + submitJobDir + " as the submit dir");// get delegation token for the dir TokenCache.obtainTokensForNamenodes(job.getCredentials(),new Path[] { submitJobDir }, conf);populateTokenCache(conf, job.getCredentials());// generate a secret to authenticate shuffle transfersif (TokenCache.getShuffleSecretKey(job.getCredentials()) == null) {KeyGenerator keyGen;try {keyGen = KeyGenerator.getInstance(SHUFFLE_KEYGEN_ALGORITHM);keyGen.init(SHUFFLE_KEY_LENGTH);} catch (NoSuchAlgorithmException e) {throw new IOException("Error generating shuffle secret key", e);}SecretKey shuffleKey = keyGen.generateKey();TokenCache.setShuffleSecretKey(shuffleKey.getEncoded(),job.getCredentials());}if (CryptoUtils.isEncryptedSpillEnabled(conf)) {conf.setInt(MRJobConfig.MR_AM_MAX_ATTEMPTS, 1);LOG.warn("Max job attempts set to 1 since encrypted intermediate" +"data spill is enabled");}copyAndConfigureFiles(job, submitJobDir);Path submitJobFile = JobSubmissionFiles.getJobConfPath(submitJobDir);// Create the splits for the jobLOG.debug("Creating splits at " + jtFs.makeQualified(submitJobDir));int maps = writeSplits(job, submitJobDir); // 為job創(chuàng)建分片 conf.setInt(MRJobConfig.NUM_MAPS, maps);LOG.info("number of splits:" + maps);// write "queue admins of the queue to which job is being submitted"// to job file.String queue = conf.get(MRJobConfig.QUEUE_NAME,JobConf.DEFAULT_QUEUE_NAME);AccessControlList acl = submitClient.getQueueAdmins(queue);conf.set(toFullPropertyName(queue,QueueACL.ADMINISTER_JOBS.getAclName()), acl.getAclString());// removing jobtoken referrals before copying the jobconf to HDFS// as the tasks don't need this setting, actually they may break// because of it if present as the referral will point to a// different job. TokenCache.cleanUpTokenReferral(conf);if (conf.getBoolean(MRJobConfig.JOB_TOKEN_TRACKING_IDS_ENABLED,MRJobConfig.DEFAULT_JOB_TOKEN_TRACKING_IDS_ENABLED)) {// Add HDFS tracking idsArrayList<String> trackingIds = new ArrayList<String>();for (Token<? extends TokenIdentifier> t :job.getCredentials().getAllTokens()) {trackingIds.add(t.decodeIdentifier().getTrackingId());}conf.setStrings(MRJobConfig.JOB_TOKEN_TRACKING_IDS,trackingIds.toArray(new String[trackingIds.size()]));}// Set reservation info if it existsReservationId reservationId = job.getReservationId();if (reservationId != null) {conf.set(MRJobConfig.RESERVATION_ID, reservationId.toString());}// Write job file to submit dir writeConf(conf, submitJobFile);//// Now, actually submit the job (using the submit name)// printTokens(jobId, job.getCredentials());status = submitClient.submitJob(jobId, submitJobDir.toString(), job.getCredentials()); // 提交 jobif (status != null) {return status;} else {throw new IOException("Could not launch job");}} finally {if (status == null) {LOG.info("Cleaning up the staging area " + submitJobDir);if (jtFs != null && submitJobDir != null)jtFs.delete(submitJobDir, true);}}}// ......private int writeSplits(org.apache.hadoop.mapreduce.JobContext job,Path jobSubmitDir) throws IOException,InterruptedException, ClassNotFoundException {JobConf jConf = (JobConf)job.getConfiguration();int maps;if (jConf.getUseNewMapper()) {maps = writeNewSplits(job, jobSubmitDir);} else {maps = writeOldSplits(jConf, jobSubmitDir);}return maps;}// ...... @SuppressWarnings("unchecked")private <T extends InputSplit>int writeNewSplits(JobContext job, Path jobSubmitDir) throws IOException,InterruptedException, ClassNotFoundException {Configuration conf = job.getConfiguration();InputFormat<?, ?> input =ReflectionUtils.newInstance(job.getInputFormatClass(), conf);List<InputSplit> splits = input.getSplits(job);T[] array = (T[]) splits.toArray(new InputSplit[splits.size()]);// sort the splits into order based on size, so that the biggest// go firstArrays.sort(array, new SplitComparator());JobSplitWriter.createSplitFiles(jobSubmitDir, conf, jobSubmitDir.getFileSystem(conf), array);return array.length;}// ......//method to write splits for old api mapper.private int writeOldSplits(JobConf job, Path jobSubmitDir) throws IOException {org.apache.hadoop.mapred.InputSplit[] splits =job.getInputFormat().getSplits(job, job.getNumMapTasks());// sort the splits into order based on size, so that the biggest// go firstArrays.sort(splits, new Comparator<org.apache.hadoop.mapred.InputSplit>() {public int compare(org.apache.hadoop.mapred.InputSplit a,org.apache.hadoop.mapred.InputSplit b) {try {long left = a.getLength();long right = b.getLength();if (left == right) {return 0;} else if (left < right) {return 1;} else {return -1;}} catch (IOException ie) {throw new RuntimeException("Problem getting input split size", ie);}}});JobSplitWriter.createSplitFiles(jobSubmitDir, job, jobSubmitDir.getFileSystem(job), splits);return splits.length;} JobSubmitter

?(1) 在抽象類 org.apache.hadoop.mapreduce.InputFormat.getSplites(JobContext?) 方法,這里實(shí)際調(diào)用的是實(shí)現(xiàn)類?org.apache.hadoop.mapreduce.lib.input.FileInputFormat.getSplites(JobContext?), ( 這里?FileInputFormat 有兩個(gè)相同的, 分別是?org.apache.hadoop.mapreduce.lib.input.FileInputFormat 和?org.apache.hadoop.mapred.FileInputFormat , 我們選擇org.apache.hadoop.mapreduce.lib.input.FileInputFormat 有以下幾點(diǎn)原因: 首先,?org.apache.hadoop.mapred.FileInputFormat 類是抽象類?InputFormat 的實(shí)現(xiàn)類; 其次, WordCount中的FileInputFormat 就是?org.apache.hadoop.mapreduce.lib.input.FileInputFormat.)

? ??我們介紹一個(gè)概念, 即新舊 MapReduce API , 從0.20.0版本開(kāi)始, Hadoop 同時(shí)提供了新舊兩套 MapReduce API. 新 API 在舊 API 基礎(chǔ)上進(jìn)行了封裝,使得其在擴(kuò)展性和易用性方面更好. 舊版 API 放在?org.apache.hadoop.mapred 包中, 而新版 API 則放在?org.apache.hadoop.mapreduce 包及其子包中.

// 該段代碼是在 org.apache.hadoop.mapreduce.InputFormat 中/** * Logically split the set of input files for the job. * * <p>Each {@link InputSplit} is then assigned to an individual {@link Mapper}* for processing.</p>** <p><i>Note</i>: The split is a <i>logical</i> split of the inputs and the* input files are not physically split into chunks. For e.g. a split could* be <i>&lt;input-file-path, start, offset&gt;</i> tuple. The InputFormat* also creates the {@link RecordReader} to read the {@link InputSplit}.* * @param context job configuration.* @return an array of {@link InputSplit}s for the job.*/public abstract List<InputSplit> getSplits(JobContext context) throws IOException, InterruptedException;

在?org.apache.hadoop.mapreduce.lib.input.FileInputFormat.getSplites(JobContext?) 方法中,

?

(2) 在抽象類?org.apache.hadoop.mapred.InputFormat.getSplites(JobContext ,int ) 方法,這里實(shí)際調(diào)用的是實(shí)現(xiàn)類?org.apache.hadoop.mapred.FileInputFormat.getSplites(JobContext ,int ) ,? 這里 ?org.apache.hadoop.mapred.FileInputFormat 類是抽象類?InputFormat 的實(shí)現(xiàn)類. 具體參考?FileInputFormat類中split切分算法和host選擇算法介紹? .?

?

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

總結(jié)

以上是生活随笔為你收集整理的WordCount作业提交到FileInputFormat类中split切分算法和host选择算法过程源码分析的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

日韩一区二区三区免费视频 | 99 精品 在线 | 日本高清dvd | 久久激情久久 | 看片网站黄 | 在线观看久草 | 欧美精品免费一区二区 | 亚洲黄污| 国产第一页在线播放 | 国产一区在线不卡 | 丝袜美女视频网站 | 在线观看国产日韩 | 五月天亚洲激情 | 深爱婷婷久久综合 | 国产午夜精品一区 | 欧美少妇xxxxxx | 97精品国产91久久久久久 | 日本不卡123区 | 园产精品久久久久久久7电影 | 中文字幕九九 | 久草资源免费 | 精品久久久久免费极品大片 | 中文字幕在线免费观看 | 日韩免费区 | 日本二区三区在线 | 亚洲成av人片在线观看 | 在线国产一区二区三区 | 国产日韩视频在线观看 | 国产精品亚州 | 国产又黄又硬又爽 | 少妇性xxx | 天天色天天射天天操 | 在线国产精品视频 | 国产首页 | 日批在线观看 | 久久综合九色综合久久久精品综合 | 大荫蒂欧美视频另类xxxx | 国产在线观看av | 九九在线国产视频 | 久久伊人精品天天 | 中文字幕av播放 | 91视频免费网站 | 日韩在线视频一区二区三区 | 天天插狠狠插 | 国产美女视频免费 | 国产一区二区综合 | 国产精品网址在线观看 | 99视频这里只有 | 欧美性受极品xxxx喷水 | 日韩精品一区二区在线视频 | 夜夜躁狠狠燥 | 色综合天天色综合 | 手机av片 | 日韩av手机在线看 | 日日夜夜骑 | 国内视频 | 涩涩网站在线播放 | 国产啊v在线观看 | 精品久久久久久亚洲综合网站 | 日韩最新在线 | 成人小视频免费在线观看 | 婷婷五天天在线视频 | 国产精品va最新国产精品视频 | 亚洲午夜精品久久久 | 99久久综合国产精品二区 | 黄色大全在线观看 | 麻豆久久久久久久 | 成人在线免费观看视视频 | 久草视频在线免费 | 黄色免费观看 | 色.www | 久久伊人八月婷婷综合激情 | 欧美影院久久 | 激情视频91 | 国产专区第一页 | 国产在线不卡精品 | 中文久久精品 | 欧美精品免费在线观看 | 精品在线观看国产 | 成人一区二区三区在线观看 | 国产成人一二三 | 欧美日韩精品免费观看 | 色婷婷久久一区二区 | 久久国产免 | 色999在线 | 天天操天天干天天操天天干 | 国产日韩在线一区 | 天天草视频| 日韩免费播放 | 日韩理论片在线观看 | 一区二区三区影院 | 中文av一区二区 | 久久亚洲影视 | 日韩色区 | 亚洲一区二区三区在线看 | 免费在线国产精品 | 婷婷丁香激情网 | 国产成人精品在线播放 | 欧美日韩亚洲一 | 久久国产精品免费看 | 欧美性生爱 | 国产成人99久久亚洲综合精品 | 久久久精品欧美 | 一区二区在线电影 | 久久精品9 | 中文字幕成人一区 | 欧美综合在线观看 | 色婷婷精品大在线视频 | 国产爽妇网 | 日韩一区正在播放 | zzijzzij亚洲成熟少妇 | 国产伦理久久精品久久久久_ | 成人久久精品视频 | 久久久久国产精品一区 | 久久久久看片 | 99精品视频免费观看 | 91黄色在线观看 | av7777777| av在线中文 | 丰满少妇一级 | 久久乐九色婷婷综合色狠狠182 | 欧美中文字幕久久 | 菠萝菠萝在线精品视频 | 国产精品久久久久久久久婷婷 | 日韩欧美xxxx | 十八岁以下禁止观看的1000个网站 | 伊人天天综合 | 国产原创av在线 | 99久久精品一区二区成人 | 欧美日韩高清在线一区 | 亚洲一区二区三区四区在线视频 | av黄色成人 | 亚洲理论在线观看 | 激情开心站| 国产黄色精品 | 九九热只有这里有精品 | 免费观看视频黄 | 久久综合九色综合久99 | 人人干人人超 | 亚洲视频综合在线 | 又色又爽又激情的59视频 | 97碰碰精品嫩模在线播放 | 国产伦理一区二区 | 欧洲一区精品 | 久久免费视频一区 | 在线观看mv的中文字幕网站 | 狠狠躁18三区二区一区ai明星 | 国产99久久九九精品免费 | 国产精品一二三 | 亚洲精品一区二区18漫画 | 91国内在线 | 免费国产ww| 亚洲涩涩一区 | av成人在线观看 | 国产1区在线观看 | 精品亚洲免费 | 奇米四色影狠狠爱7777 | 成人97人人超碰人人99 | 国产黄免费在线观看 | 亚洲国产精品影院 | 日本精品久久久久影院 | 国产精品一区二区三区四 | 欧美日韩一区二区三区在线免费观看 | 天天干天天干天天干 | 国产精品综合久久久 | av+在线播放在线播放 | 久久蜜臀一区二区三区av | 99在线精品视频观看 | 欧美aa在线 | 色综合久久综合网 | 成人亚洲精品国产www | 又粗又长又大又爽又黄少妇毛片 | 中文亚洲欧美日韩 | 久久66热这里只有精品 | 精品乱码一区二区三四区 | 在线亚洲欧美视频 | 国产理伦在线 | 日韩欧美一区二区在线观看 | 欧美日韩不卡一区二区三区 | 五月天综合在线 | 成人在线你懂得 | 九九热在线视频 | 国内少妇自拍视频一区 | 激情网在线观看 | 亚洲免费av在线播放 | 欧美久久久久久久久久久久久 | 久久国产精品影视 | 在线观看视频色 | 国产精品免费视频久久久 | 成 人 a v天堂| 国产成人久久精品一区二区三区 | 精品国产免费看 | 在线观看午夜av | 欧美淫aaa免费观看 日韩激情免费视频 | 国产精品9999久久久久仙踪林 | 国内精品中文字幕 | 久久精品国产亚洲aⅴ | 少妇性xxx | 久久在草 | 丁香六月综合网 | 在线观看av网 | 青青久草在线视频 | av动图| 一区二区电影在线观看 | 一区二区在线电影 | 久久久麻豆精品一区二区 | 国产剧情av在线播放 | av在线免费网站 | 涩五月婷婷 | 国内精品美女在线观看 | 欧美精品一区二区在线播放 | 免费在线观看成人小视频 | 日韩欧美视频在线播放 | 成人精品视频 | 亚洲国产精彩中文乱码av | 亚洲天天综合网 | 国产九九热视频 | 麻花豆传媒mv在线观看 | 夜夜躁日日躁狠狠久久av | 日韩精品一区二区在线观看 | 九九导航 | 婷婷激情在线 | 国产在线91在线电影 | 中文字幕成人一区 | 91在线看 | 日韩精品免费 | 日本黄区免费视频观看 | 超碰av在线播放 | 亚洲视频在线观看网站 | 日韩区欧美久久久无人区 | 亚洲国内精品在线 | 久久精品人人做人人综合老师 | 在线观看的黄色 | 91九色在线视频观看 | 99精品免费 | 五月婷婷丁香色 | 丁香网五月天 | 色噜噜在线观看 | 国产精品一区免费观看 | 欧美日韩久久 | 激情欧美一区二区三区免费看 | 欧美成人在线网站 | 97色国产 | 国产精品免费在线 | 激情综合亚洲精品 | 亚洲精品美女视频 | 人人干人人上 | 国产成人三级三级三级97 | 国产区高清在线 | 国产91精品久久久久久 | 久久久首页 | 国产99视频在线观看 | 中文区中文字幕免费看 | 玖玖色在线观看 | 日韩久久精品一区 | 91看片成人 | 色999精品| 国产精品高潮呻吟久久av无 | 狠狠综合久久 | 日韩在线观看视频中文字幕 | 国产成人精品久 | 国产精品久久久亚洲 | 亚洲精品在线视频观看 | 九七视频在线观看 | 国产精品av在线免费观看 | 在线观看国产91 | 欧美激情精品 | 99国产精品视频免费观看一公开 | 国产精品精品国产 | 7777精品伊人久久久大香线蕉 | 久久久久久久久久毛片 | 99久久精品国产免费看不卡 | 日韩久久精品一区 | 久久免费的视频 | 亚洲日本精品 | 日韩高清免费无专码区 | 久久综合久久鬼 | 亚洲 成人 欧美 | 在线视频欧美精品 | 最新中文字幕在线观看视频 | 福利久久| 一区二区三区在线看 | 亚洲艳情| 国产高清精 | 国产精品女人久久久 | 久久久91精品国产一区二区精品 | 在线视频婷婷 | 精品一区欧美 | 五月天视频网 | 亚洲网久久 | 狠狠干夜夜爽 | 欧美精品v国产精品v日韩精品 | 亚洲精品乱码久久久久久9色 | 色综合久久综合中文综合网 | 日韩色爱| 99精品免费在线 | 美女国产在线 | 国产91对白在线播 | 欧美日韩激情视频8区 | 夜夜干天天操 | 在线电影a| www.婷婷com| 亚洲一区精品二人人爽久久 | 国产一区二区视频在线播放 | 97超碰在线久草超碰在线观看 | .精品久久久麻豆国产精品 亚洲va欧美 | 精品一区二区免费 | 天天干,天天操 | 91视频首页 | 国产视频黄 | 麻豆小视频在线观看 | 国产a高清 | 色综合久久天天 | 正在播放久久 | 亚洲精品乱码久久久久久按摩 | 玖玖在线观看视频 | 免费观看性生活大片3 | 欧美视频国产视频 | 日韩欧美视频一区二区 | 国产精品成人在线观看 | 国产高清福利在线 | 国产在线a视频 | 人人玩人人添人人 | www.久久久久 | 成人av网页 | 97精品国产97久久久久久 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 欧美在线你懂的 | 久久久精品亚洲 | 一区二区三区在线电影 | 波多野结衣亚洲一区二区 | 9热精品| 欧美在线观看视频免费 | 亚洲成人免费在线观看 | 久久人人爽爽人人爽人人片av | 色88久久| 91精品小视频 | 黄色精品一区二区 | 韩国精品一区二区三区六区色诱 | av高清影院 | 丁香六月五月婷婷 | 色综合久久中文字幕综合网 | 国产日韩欧美在线观看视频 | 欧美性直播 | 丰满少妇在线观看网站 | 毛片网站在线看 | www视频在线观看 | 免费看色网站 | 久久国产成人午夜av影院潦草 | 美女精品久久久 | www.久久91 | 日韩视频在线不卡 | 爱色婷婷| 日韩免费一二三区 | 99精品影视| 又黄又爽又无遮挡的视频 | 国产免费亚洲高清 | 久久情网 | 丁香在线视频 | 久久久91精品国产 | 黄在线免费看 | 成人一区不卡 | 国产一区在线视频观看 | 日韩在线第一区 | 丁香五婷 | 亚洲精品国产欧美在线观看 | 99精品在线看 | 美女视频黄网站 | 美女av在线免费 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 久草在线在线精品观看 | 超碰人人99 | 五月天综合色激情 | 久久精品香蕉视频 | 国产va饥渴难耐女保洁员在线观看 | 狠狠色丁香婷婷综合 | 国产精品久久久久久久久毛片 | 九九导航 | 亚洲动漫在线观看 | 99久久夜色精品国产亚洲 | 国产区第一页 | 日韩免费在线 | 久久夜色精品国产欧美一区麻豆 | 亚洲播放一区 | 天天操操操操操操 | 高潮久久久久久 | 欧美日韩精| 中文字幕精品三级久久久 | 亚洲精品视频在线 | 国产一区二区不卡视频 | 国产精品黑丝在线观看 | 日韩午夜电影 | 国产成人久久精品77777 | 中文字幕视频一区二区 | 久草在线观看 | 成人国产精品av | 97精品在线视频 | 97在线免费视频观看 | 久久精品欧美一 | 亚洲在线视频免费 | 天天干一干| 超碰最新网址 | 久久久精品 一区二区三区 国产99视频在线观看 | a黄色大片 | 婷婷在线综合 | 嫩草伊人久久精品少妇av | 中文字幕一区二区三区在线播放 | 一区二区三区电影在线播 | 亚洲精品在线观看av | 最近日本中文字幕a | 免费在线观看视频a | 日本精品中文字幕 | 91黄在线看| 久久情网 | 日韩精品一区电影 | 日韩一区视频在线 | 国产精品短视频 | 成人免费一级片 | 久久精品国产一区二区电影 | 久一久久 | 精品国产电影一区 | www.成人久久 | 91片黄在线观看 | 国产女教师精品久久av | 免费a v网站 | 精品99免费 | 久久理论电影网 | 精品毛片在线 | 欧美黑人巨大xxxxx | 亚洲精品视频在线免费播放 | av成人在线网站 | a级国产乱理伦片在线观看 亚洲3级 | 午夜视频一区二区三区 | 国产精品成人一区二区三区吃奶 | 亚洲播播 | 91成人亚洲 | 国语精品免费视频 | 91最新在线 | 97国产超碰在线 | 在线观看韩国av | 中文字幕在线播放视频 | 国产成人精品一区二区三区 | 国产亚洲一区二区在线观看 | 美女在线免费视频 | 欧美一区日韩一区 | 天天干天天爽 | 婷婷色亚洲 | 人人爽久久久噜噜噜电影 | 一区二区三区四区五区六区 | 国产最顶级的黄色片在线免费观看 | 久久久.com | 波多野结衣亚洲一区二区 | 青青河边草免费 | 亚洲在线激情 | 亚洲精品福利视频 | 国产视频在线观看一区 | 免费看十八岁美女 | 人人插人人插 | 日韩欧美国产成人 | 最近高清中文在线字幕在线观看 | 国产日韩视频在线播放 | 91精品电影 | 久久只精品99品免费久23小说 | 国产日本在线 | 日批视频国产 | 久久视讯 | 中文字幕在线观看网站 | 久久免费看毛片 | 久久视频在线观看中文字幕 | 国产乱老熟视频网88av | 日韩网站在线免费观看 | 正在播放 国产精品 | 国产一级片久久 | 六月婷婷网 | 欧美一级在线观看视频 | 99久久99久久免费精品蜜臀 | 91精彩视频| 日本在线观看一区 | 免费视频久久久久 | 久草久草视频 | 91精品国产一区二区三区 | 午夜手机电影 | 亚洲乱码久久 | 国产69熟| 18国产精品福利片久久婷 | 免费av网站观看 | 四虎在线影视 | 精品国模一区二区三区 | 亚洲 综合 国产 精品 | 水蜜桃亚洲一二三四在线 | 久久国产精品一二三区 | 久久久久伊人 | 九九九九精品九九九九 | 国产小视频在线播放 | 天天射天天舔天天干 | 国产又粗又长又硬免费视频 | 91精品国产综合久久婷婷香蕉 | 不卡的av在线 | 亚洲色图色 | 波多野结衣精品 | 欧美日韩在线观看一区二区三区 | 91视频下载 | 亚洲精品欧美视频 | 日韩欧美国产精品 | 91在线日本| 成人黄色小说视频 | 欧美日bb | 成人理论在线观看 | 日韩av不卡在线观看 | 国内揄拍国内精品 | 超碰97公开 | 国产亚洲无 | av中文在线影视 | 亚洲精品短视频 | 久久国产精品久久精品国产演员表 | 五月天久久激情 | 黄网站色成年免费观看 | 999热线在线观看 | 久青草电影| 夜夜摸夜夜爽 | 五月婷婷综合激情 | 99爱视频 | 成年人免费在线 | 久久草精品 | 免费看成人 | 欧美国产在线看 | av中文字幕第一页 | 久久色在线播放 | 国产精品久久久久av | 91精选在线| 国产福利91精品 | 色吊丝在线永久观看最新版本 | 麻豆成人在线观看 | 欧美精品乱码99久久影院 | 久久视频在线看 | 在线精品视频免费播放 | 91精品视频免费看 | 欧美亚洲另类在线视频 | av黄网站 | 色综合 久久精品 | 99av国产精品欲麻豆 | 久久福利| 蜜臀av性久久久久av蜜臀三区 | 欧美日韩国产综合一区二区 | 亚洲男男gaygayxxxgv| www.色爱| 欧美成人一区二区 | 少妇bbw撒尿 | 国产精品6 | 国产一区av在线 | 久草电影在线观看 | 国产视频在线观看一区 | 色播五月激情综合网 | 国产在线国偷精品产拍免费yy | 久草在线免费新视频 | 五月婷婷在线视频 | 天天天天爱天天躁 | 成人在线播放免费观看 | 一区二区三区av在线 | 黄色在线免费观看网站 | 中文字幕a∨在线乱码免费看 | 制服丝袜亚洲 | av免费在线观看网站 | 又色又爽又黄 | 97国产精品亚洲精品 | 在线播放国产精品 | 日本精品视频一区二区 | 久久综合久久88 | 久久综合欧美 | a黄色片| 亚洲精品动漫久久久久 | 五月天亚洲精品 | 久久看免费视频 | 极品美女被弄高潮视频网站 | 91av视频在线免费观看 | 伊人五月在线 | a级一a一级在线观看 | 国产香蕉久久 | 美女网站色免费 | 手机在线看永久av片免费 | 狠狠色丁香婷婷 | 人人澡人人干 | 国产视频欧美视频 | 亚洲欧美va | 91高清一区 | 日本精品视频网站 | www欧美日韩| 日日操日日插 | 伊人网站| 亚洲成aⅴ人片久久青草影院 | 久久影视精品 | 超碰国产在线播放 | 久久毛片高清国产 | av超碰在线| 91在线观看黄 | 国产精品久久久久久69 | www.夜夜爱| 天天摸天天干天天操天天射 | 天天干天天草天天爽 | 蜜臀av夜夜澡人人爽人人桃色 | 丝袜美腿在线播放 | 蜜臀久久99静品久久久久久 | 国产在线理论片 | 在线电影 你懂得 | 久久天天躁夜夜躁狠狠85麻豆 | 99久久精| 亚洲精品永久免费视频 | 久久成人在线视频 | 久久久福利视频 | 免费成人黄色 | 国产精品综合久久 | 99久久日韩精品免费热麻豆美女 | 免费看久久久 | 国产精品国产自产拍高清av | 麻豆影音先锋 | 亚洲 欧美 国产 va在线影院 | 免费在线观看亚洲视频 | 九九热久久久 | 亚洲综合视频在线 | 国产一级电影免费观看 | www.com操| 久久免费公开视频 | 精品96久久久久久中文字幕无 | 欧美日韩性视频在线 | 亚洲年轻女教师毛茸茸 | 在线观看视频你懂的 | 人人插人人爱 | 亚洲精品视频在线播放 | 永久免费在线 | 午夜精品导航 | 亚洲va韩国va欧美va精四季 | 亚洲精品乱码久久久久 | 国语麻豆| 国产美女免费看 | 婷婷丁香在线观看 | 国产视频精品在线 | 中文字幕一区二区三区乱码在线 | 91豆花在线观看 | 一区二区视频在线观看免费 | 久久久国产精品麻豆 | 久久看免费视频 | 日韩乱理 | 黄色免费在线视频 | 日日夜夜精品免费 | 国产视频在线观看一区 | 免费一级黄色 | av在线8| 成人电影毛片 | 久久综合免费视频 | 五月婷婷色 | 91黄在线看 | www·22com天天操| 日本电影黄色 | 国产做爰视频 | 国产精品99久久久久久人免费 | 久久图| 日韩精品短视频 | 国产精品福利在线播放 | 三级黄色在线观看 | www.大网伊人 | 亚洲精品2区 | 超碰免费久久 | 91久久精品日日躁夜夜躁国产 | 国产男女无遮挡猛进猛出在线观看 | 日韩激情片在线观看 | 国产一级性生活视频 | 激情网婷婷 | 狠狠干狠狠色 | 国产精品综合久久久久久 | 日日麻批40分钟视频免费观看 | 色综合激情久久 | 毛片99 | 在线免费观看黄网站 | 狠狠躁夜夜躁人人爽超碰91 | 99久久精品久久久久久动态片 | 国产成人精品亚洲a | 成人一级片视频 | 国产自制av | 人人澡人人草 | 中文字幕一区二区三区乱码在线 | 亚洲免费av片 | 婷婷婷国产在线视频 | 欧美一级专区免费大片 | 国产在线精品一区二区不卡了 | 一区二区三区久久 | 午夜国产在线 | 久久人人爽人人爽人人片av免费 | 在线一二三区 | 久草网首页 | 午夜精品久久久久久久99 | 日韩亚洲欧美中文字幕 | 91视频下载 | 97在线播放| 毛片在线网 | 欧亚日韩精品一区二区在线 | 97在线精品 | 粉嫩一区二区三区粉嫩91 | 国产福利av | 天天操天天爱天天干 | 亚洲精品mv在线观看 | 97热视频 | 国产三级精品三级在线观看 | 蜜桃麻豆www久久囤产精品 | 国产在线探花 | 人人爽人人射 | 一级黄色片在线播放 | av性网站| 精品成人免费 | 欧美日韩中文在线观看 | 欧美精品久久久久久久免费 | 91精品综合在线观看 | 在线观看一区二区精品 | 国产精品一区二区美女视频免费看 | 久久97视频| 91精品国产高清自在线观看 | 国产黄在线播放 | 日韩视频免费观看高清 | 久久精品直播 | 干狠狠| 精品伊人久久久 | 日本久久中文 | 日日激情 | 91精品一区二区三区蜜臀 | 国产美女视频网站 | 免费污片 | 午夜精品一区二区三区视频免费看 | 日日干天天 | 日韩在线观看视频网站 | 日韩99热| 亚洲国产精品传媒在线观看 | 国产做aⅴ在线视频播放 | 色婷婷在线观看视频 | 日韩资源在线观看 | 不卡的av电影在线观看 | av大全在线| 美女免费黄网站 | 丁香九月婷婷 | 久久久久网址 | 成人黄大片视频在线观看 | 丝袜美腿在线播放 | 在线欧美小视频 | 成人一区影院 | 国产在线播放不卡 | 91精品久久久久久久91蜜桃 | 免费在线激情视频 | 黄色视屏av | 91在线精品一区二区 | 国产黄av | 国精产品999国精产品视频 | 国产97视频在线 | 人人爽人人搞 | 日韩性xxxx | 亚洲v精品 | 国产精品va在线 | 在线观看你懂的网站 | 五月天狠狠操 | 色黄久久久久久 | 国产91免费在线观看 | 一区二区三区在线免费播放 | 正在播放日韩 | 在线观看中文字幕视频 | 精品国产精品国产偷麻豆 | 99色网站| 狂野欧美激情性xxxx欧美 | 国产在线不卡视频 | 男女视频久久久 | 天天爽夜夜爽人人爽曰av | 久久久精品欧美 | 91片黄在线观看 | 特黄特黄的视频 | 字幕网在线观看 | 久久综合五月 | 国产群p | 欧美久久久久久久久久久 | 黄色精品网站 | 婷婷5月激情5月 | 久久国产99 | 久草在线资源观看 | 国产免费嫩草影院 | caobi视频| 国产精品久久久久久久久久99 | 久久久精品欧美一区二区免费 | avwww在线观看| 特黄色大片 | 视频一区在线播放 | 狠狠色丁香婷婷综合基地 | 亚洲黄色一级电影 | 视频成人永久免费视频 | 婷婷 综合 色 | 美女网站在线观看 | 天天插天天操天天干 | 亚洲欧美日韩一二三区 | 视频一区在线播放 | 国产精品免费视频一区二区 | 91麻豆精品国产自产在线 | 中文字幕日韩国产 | 国产香蕉av | 日韩欧美国产精品 | 日韩欧美综合视频 | 免费a级黄色毛片 | 免费观看www小视频的软件 | 国产第一页福利影院 | 色诱亚洲精品久久久久久 | 中文字幕一区二区三区在线视频 | 亚洲国产大片 | 狠狠色婷婷丁香六月 | 国产色拍拍拍拍在线精品 | 成人h视频在线播放 | 午夜精品视频在线 | 三级大片网站 | 99久久精品无码一区二区毛片 | 亚洲精品乱码久久久一二三 | 中文字幕乱偷在线 | 国产一区二区三精品久久久无广告 | av三级在线播放 | 国产在线精品国自产拍影院 | 中文字幕999 | 自拍超碰在线 | 夜夜夜精品 | 久草资源在线观看 | 69av网| 蜜臀精品久久久久久蜜臀 | 午夜精品av| 在线a视频免费观看 | 日韩中文在线视频 | 国产视频一区在线播放 | 国产一级二级在线观看 | 国产在线一区二区三区播放 | 色吊丝av中文字幕 | 天天爽夜夜操 | 国产精品免费在线视频 | 永久免费的啪啪网站免费观看浪潮 | 中文字幕一区二区三区四区久久 | 久久精品香蕉视频 | 激情网在线观看 | 国产日产精品一区二区三区四区的观看方式 | 国产第一二区 | 日韩黄色中文字幕 | 欧美成人a在线 | 日韩av免费大片 | 日韩免费视频一区二区 | 成人h动漫在线看 | 一级片视频免费观看 | 玖玖精品在线 | 欧美日韩精品在线视频 | 青草视频在线播放 | 五月天亚洲婷婷 | 成人久久18免费网站 | www.色五月.com| 人交video另类hd | 精品国产一区二区三区不卡 | 可以免费看av | 中文字幕在线看片 | 特级a老妇做爰全过程 | 国产91综合一区在线观看 | 国产精品久久网站 | 蜜臀av性久久久久蜜臀av | av成年人电影 | 日韩精品免费一线在线观看 | 国产香蕉在线 | 97视频在线观看网址 | 欧美日韩久久不卡 | 欧美在线观看视频免费 | 国产精品免费久久 | 国产精品乱码久久 | 在线导航福利 | sm免费xx网站 | 自拍超碰在线 | 狠狠操91| 免费高清在线观看电视网站 | 欧美一级艳片视频免费观看 | 免费在线观看不卡av | 97视频在线播放 | 99久热精品 | 欧美精品一区二区在线播放 | 欧美精品免费在线观看 | 伊人久久av | 天天干,天天操,天天射 | 亚洲精品中文字幕视频 | 九九电影在线 | 狠狠狠综合 | 波多野结衣一区二区 | 在线看成人| 在线亚洲精品 | 国内精品久久久久影院男同志 | 四虎在线免费观看 | 特黄免费av | 日韩av电影网站在线观看 | 亚洲综合爱 | 人人干人人艹 | 日韩理论在线 | 免费大片黄在线 | 亚洲国产日韩av | 久久精品视频在线观看 | 中文字幕第一页在线 | 激情网在线视频 | 中文字幕一区二 | a天堂最新版中文在线地址 久久99久久精品国产 | 免费av影视| 欧美最猛性xxxxx免费 | 在线视频a| 成人午夜电影久久影院 | 日本中文不卡 | 亚洲欧美日韩在线一区二区 | 国产又粗又猛又黄又爽视频 | 亚洲色图色 | 91麻豆精品一区二区三区 | 久久精品99国产精品酒店日本 | 欧美极度另类 | 中文字幕国产一区二区 | 久久久久久综合网天天 | 正在播放久久 | 国内揄拍国产精品 | 国产伦精品一区二区三区照片91 | 成人va视频 | 国产精品99久久久久人中文网介绍 | 在线免费观看黄网站 | 成人av电影网址 | 日日夜夜综合网 | 亚洲精品中文字幕在线 | 精品亚洲一区二区三区 | 久久精品中文字幕一区二区三区 | 亚洲日本va午夜在线影院 | 国产99久久99热这里精品5 | 尤物一区二区三区 | 欧美大jb | 四虎视频 | 99re国产| 国产日产精品一区二区三区四区的观看方式 | 免费日韩一级片 | 在线观看中文字幕2021 | 手机av在线免费观看 | 成人一级片视频 | 国产精彩视频 | 日韩中文在线视频 | 免费久久久| 日韩av在线高清 | 久草电影免费在线观看 | 亚洲成av人影院 | 久久综合影音 | 性色av免费在线观看 | 久久久免费毛片 | 国产高清在线视频 | 91热| 精品久久久久久久久久久久久 | 久久亚洲婷婷 | 国产一区二区免费 | 天天干天天操 | 日韩一区精品 | 欧美激情xxxx性bbbb | 精品久久免费看 | 国产精品国产三级国产aⅴ入口 | 亚洲精品中文字幕在线观看 | 欧美狠狠色 | 精品一区av | 国产最顶级的黄色片在线免费观看 | 国产精品成人久久久 | 欧美成人h版电影 | 国模精品在线 | 在线观看亚洲精品视频 | 亚洲美女视频在线 | 久久经典国产 | 久久首页| 久久久久久久久影院 | 91精品国产91久久久久福利 | 超级碰99| 88av网站 | 精品亚洲午夜久久久久91 | 亚洲精品在线播放视频 | 日日日操操 | 美女国产免费 | 午夜视频一区二区三区 | 国产成人精品一二三区 | 久久免费视频在线观看6 | 日本激情视频中文字幕 | 人人舔人人爱 | 日韩欧美一级二级 | 一区二区三区日韩精品 | 久久久免费播放 | 国产日韩一区在线 | 精品国产1区 | 亚洲激情一区二区三区 | 亚洲国产成人精品在线 | 欧美一级电影在线观看 | 香蕉视频在线观看免费 | 国产精品入口66mio女同 | 精品成人久久 | 成人久久综合 | 射久久| 亚洲精品午夜国产va久久成人 | www免费 | 久久久久欧美精品 | 久久国产精品久久w女人spa | 久久这里只有精品1 | 欧美久草视频 | 国产精品va在线播放 | 久久人操| 伊人开心激情 |