亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

MapReduce并行編程模型和框架

2019-11-11 03:42:48
字體:
來源:轉載
供稿:網友

傳統的串行處理方式

有四組文本數據:

“the weather is good”, “today is good”, “good weather is good”, “today has good weather”

對這些文本數據進行詞頻統計:

import java.util.Hashtable;import java.util.Iterator;import java.util.StringTokenizer;/** * 傳統的串行計算方式詞頻統計 * * @version 2017年1月12日 下午4:05:33 */public class WordCount { public static void main(String[] args) { String[] text = new String[]{ "the weather is good","today is good", "good weather is good","today has good weather" }; //同步、線程安全 Hashtable ht = new Hashtable(); //HashMap ht = new HashMap(); for(int i=0;i<=3;i++){ //字符串根據分隔符解析 StringTokenizer st = new StringTokenizer(text[i]); while (st.hasMoreTokens()) { String world = st.nextToken(); if(!ht.containsKey(world)){ ht.put(world, new Integer(1)); }else{ int wc = ((Integer)ht.get(world)).intValue()+1; ht.put(world, new Integer(wc)); } }//end of while }//end of for //輸出統計結果 for(Iterator itr = ht.keySet().iterator();itr.hasNext();){ String world = (String) itr.next(); System.out.一個MR分布式程序

求出每個年份的最高氣溫:

MaxTemperatureMapper.Java:import java.io.IOException;import org.apache.hadoop.io.IntWritable;import org.apache.hadoop.io.LongWritable;import org.apache.hadoop.io.Text;import org.apache.hadoop.mapreduce.Mapper;public class MaxTemperatureMapper extends Mapper<LongWritable, Text,Text, IntWritable>{ @Override protected void map(LongWritable key, Text value, Mapper<LongWritable, Text, Text, IntWritable>.Context context) throws IOException, InterruptedException { //解析字段 String line =value.toString(); try{ String year = line.substring(0,4); int airTemperature =Integer.parseInt(line.substring(5)); context.write(new Text(year),new IntWritable(airTemperature)); }catch(Exception e){ System.out.println("error in line:" + line); } }} MaxTemperatureReducer.java:import java.io.IOException;import org.apache.hadoop.io.IntWritable;import org.apache.hadoop.io.Text;import org.apache.hadoop.mapreduce.Reducer;/** * reducer 比較每年度溫度最高值 * */public class MaxTemperatureReducer extends Reducer<Text, IntWritable, Text, IntWritable> { @Override protected void reduce(Text key, Iterable<IntWritable> values, Reducer<Text, IntWritable, Text, IntWritable>.Context context) throws IOException, InterruptedException { int MaxValue = Integer.MIN_VALUE; for(IntWritable value:values){ MaxValue = Math.max(MaxValue, value.get()); } context.write(key , new IntWritable(MaxValue)); }}MaxTemperatureDriver.java:import org.apache.hadoop.conf.Configuration;import org.apache.hadoop.conf.Configured;import org.apache.hadoop.fs.Path;import org.apache.hadoop.io.IntWritable;import org.apache.hadoop.io.Text;import org.apache.hadoop.mapreduce.Job;import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;import org.apache.hadoop.util.Tool;import org.apache.hadoop.util.ToolRunner;public class MaxTemperatureDriver extends Configured implements Tool{ @Override public int run(String[] args) throws Exception { // 對 參數進行判斷:參數個數不為2,打印錯誤信息 if (args.length != 2){ System.err.printf("Usage: %s <input><output>",getClass().getSimpleName()); ToolRunner.printGenericCommandUsage(System.err); return -1; } Configuration conf =getConf(); @SuppressWarnings("deprecation") //不檢測過期的方法 Job job = new Job(conf); job.setJobName("Max Temperature"); job.setJarByClass(getClass()); FileInputFormat.addInputPath(job,new Path(args[0])); FileOutputFormat.setOutputPath(job,new Path(args[1])); job.setMapperClass(MaxTemperatureMapper.class); job.setReducerClass(MaxTemperatureReducer.class); job.setOutputKeyClass(Text.class); job.setOutputValueClass(IntWritable.class); return job.waitForCompletion(true)?0:1; } public static void main(String[] args)throws Exception{ int exitcode = ToolRunner.run(new MaxTemperatureDriver(), args); System.exit(exitcode); }}

上傳數據至hadoop集群:

這里寫圖片描述

原始數據: Temperature1:

1990 211990 181991 211992 301990 21

Temperature2:

1991 211990 181991 241992 301993 21

將程序打包上傳至主節點某個目錄下,執行

hadoop jar /data/jar/maxtemperature.jar hdfs://192.168.75.128:9000/input hdfs://192.168.75.128:9000/output/temperature

執行結果:

結果數據:

1990 211991 241992 301993 21

完整的MapReduce編程模型

Combiner:進行中間結果數據網絡傳輸優化的工作。Combiner程序的執行是在Map節點完成計算之后、輸出結果之前。

Partitioner:將所有主鍵相同的鍵值對傳輸給同一個Reduce節點。分區的過程在Map節點輸出后、傳入Reduce節點之前完成的。

下面是針對四組數據的MapReduce完整的并行編程模型:

“the weather is good”, “today is good”, “good weather is good”, “today has good weather”

這里寫圖片描述

完整的MapReduce編程模型

(1)用戶程序會分成三個部分:Mapper,Reducer,Driver (2)Mapper的輸入數據是KV對的形式,KV的類型可以設置 (3)Mapper的輸出數據是KV對的形式,KV的類型可以設置 (4)Mapper中的業務邏輯寫在map方法中 (5)map方法是每進來一個KV對調用一次 (6)Reducer的輸入數據應該對應Mapper的輸出數據,也是KV (7)Reducer的業務邏輯寫在reduce方法中 (8)reduce方法是對每一個< key,valueList> 調用一次 (9)用戶的Mapper和Reducer都要繼承各自的父類 (10)整個程序需要一個Drvier來進行提交,提交的是一個描述了各種必要信息的job對象。

Hadoop系統架構和MapReduce執行流程

為了實現Hadoop系統設計中本地化計算的原則,數據存儲節點DataNode與計算節點TaskTracker將合并設置,讓每個從節點同時運行作為DataNode和TaskTracker,以此讓每個Tasktracker盡量處理存儲在本地DataNode上的數據。

而數據存儲主控節點NameNode與作業執行主控節點JobTracker既可以設置在同一個主控節點上,在集群規模較大或者這兩個主控節點負載都很高以至于互相影響時,也可以分開設置在兩個不同的節點上。

這里寫圖片描述

Hadoop系統的基本組成構架

MapReduce程序的執行流程:

MapReduce執行一個用戶提交的MapReduce程序的基本過程。

這里寫圖片描述

Hadoop MapReduce 程序執行流程

1) 首先,用戶程序客戶端通過作業客戶端接口程序JobClient提交一個用戶程序。 2) 然后JobClient向JobTracker提交作業執行請求并獲得一個Job ID。 3) JobClient同時也會將用戶程序作業和待處理的數據文件信息準備好并存儲在HDFS中。 4) JobClient正式向JobTracker提交和執行該作業。 5) JobTracker接受并調度該作業,進行作業的初始化準備工作,根據待處理數據的實際分片情況,調度和分配一定的Map節點來完成作業。 6) JobTracker 查詢作業中的數據分片信息,構建并準備相應的任務。 7) JobTracker 啟動TaskTracker節點開始執行具體的任務。 8) TaskTracker根據所分配的具體任務,獲取相應的作業數據。 9) TaskTracker節點創建所需要的Java虛擬機,并啟動相應的Map任務(或Reduce任務)的執行。 10) TaskTracker執行完所分配的任務之后,若是Map任務,則把中間結果數據輸出到HDFS中;若是Reduce任務,則輸出最終結果。 11) TaskTracker向JobTracker報告所分配的任務的完成。若是Map任務完成并且后續還有Reduce任務,則JobTracker會分配和啟動Reduce節點繼續處理中間結果并輸出最終結果。

參考學習資料:

1.HashMap和Hashtable的區別: http://www.importnew.com/7010.html 2.StringTokenizer類的使用方法: http://yacole.iteye.com/blog/41512


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美高清在线观看| 日韩中文第一页| 日韩精品中文字幕在线| 国产精品爽爽爽爽爽爽在线观看| 正在播放国产一区| 久操成人在线视频| 久久亚洲精品一区| 97久久国产精品| 欧美日韩在线视频观看| 美女黄色丝袜一区| 91精品在线看| 欧美成人一区二区三区电影| 国产精品va在线| 精品亚洲aⅴ在线观看| 日韩免费观看高清| 久久久999精品免费| 日韩av在线一区二区| 91欧美精品午夜性色福利在线| 国产一区二区三区精品久久久| 亚洲色图色老头| 国产精品aaaa| 精品成人av一区| 在线精品国产欧美| 国产极品jizzhd欧美| 国产欧美va欧美va香蕉在线| 欧洲日韩成人av| 欧美成人免费全部观看天天性色| 欧美www视频在线观看| 欧美电影免费观看高清完整| 日韩av电影中文字幕| 精品一区二区电影| 在线观看不卡av| 成人欧美一区二区三区黑人| 久久久久久久色| 久久人91精品久久久久久不卡| 成人妇女淫片aaaa视频| 欧美日韩另类视频| 亚洲第一页中文字幕| 久久精彩免费视频| 亚洲自拍偷拍区| 日本精品在线视频| 欧美精品久久久久久久久久| 国产成人啪精品视频免费网| 91豆花精品一区| 亚洲人成网站在线播| 日韩欧美中文在线| 欧美高清视频在线| 国产日韩中文字幕在线| 亚洲美女www午夜| 国产99视频在线观看| 亚洲尤物视频网| 一本色道久久88综合亚洲精品ⅰ| 日本成人精品在线| 国产欧美日韩精品专区| 亚洲国产精品久久久久久| 欧美日韩在线视频观看| 精品亚洲国产视频| 成人免费看片视频| www.日韩欧美| 久久青草精品视频免费观看| 精品丝袜一区二区三区| 欧美日韩ab片| 国产精品中文字幕在线观看| 91精品国产91久久久久久不卡| 国产一区二区精品丝袜| 亚洲护士老师的毛茸茸最新章节| 国产精品中文字幕在线观看| 久久久人成影片一区二区三区观看| 热re99久久精品国产66热| 91国内免费在线视频| 最近2019中文字幕第三页视频| 国产精品视频自在线| 久久久国产视频| 欧美性高跟鞋xxxxhd| 欧美日韩国产成人在线| 亚洲天堂av电影| 色综合色综合久久综合频道88| 亚洲精品wwwww| 欧美成人sm免费视频| 国产成人一区三区| 亚洲japanese制服美女| 欧美精品精品精品精品免费| 欧美性在线观看| 日韩大陆欧美高清视频区| 国内偷自视频区视频综合| 国产午夜精品全部视频在线播放| 日韩成人小视频| 亚洲欧美国产一区二区三区| 欧美另类高清videos| 成人精品福利视频| 国内精品久久久久久影视8| 亚洲最大成人在线| 国产91精品久久久久久| 欧美大尺度电影在线观看| 国产精品白丝av嫩草影院| 日韩av色综合| 久久中文字幕视频| 色777狠狠综合秋免鲁丝| 成人美女免费网站视频| 久久精品国产91精品亚洲| 丝袜亚洲另类欧美重口| 日韩免费在线观看视频| 欧美人与性动交| 尤物yw午夜国产精品视频| 亚洲国产精久久久久久| 国产精品劲爆视频| 日韩欧美亚洲国产一区| 欧美性xxxx极品高清hd直播| 一区二区三区无码高清视频| 亚洲国产另类 国产精品国产免费| 欧美国产精品人人做人人爱| 国产亚洲精品成人av久久ww| 欧美激情高清视频| 久久精品视频播放| 日韩欧美国产一区二区| 亚洲人成亚洲人成在线观看| 日韩中文字幕av| 国产欧美一区二区白浆黑人| 福利精品视频在线| 欧美日韩国产精品一区| 日本一区二区在线免费播放| 色噜噜久久综合伊人一本| 中文在线不卡视频| 最近中文字幕2019免费| 丝袜美腿亚洲一区二区| 精品久久国产精品| 欧美第一黄网免费网站| 亚洲无亚洲人成网站77777| 久久理论片午夜琪琪电影网| 国产精品丝袜久久久久久高清| 日韩av色在线| 97碰碰碰免费色视频| 国产精品久久9| 日本国产高清不卡| 日韩精品日韩在线观看| 中文字幕欧美日韩在线| 最近2019年中文视频免费在线观看| 一个人看的www久久| 国产精品手机播放| 国产精品亚洲片夜色在线| 欧美亚洲午夜视频在线观看| 国产美女扒开尿口久久久| 久久久久一本一区二区青青蜜月| 欧美一性一乱一交一视频| 亚洲精品91美女久久久久久久| 亚洲一区二区精品| 中文字幕日韩有码| 欧美激情欧美激情| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产精品亚洲一区二区三区| 91免费综合在线| 久久精品国产清自在天天线| 国产一区二区日韩精品欧美精品| 中文字幕av日韩| zzijzzij亚洲日本成熟少妇| 欧美精品国产精品日韩精品| 欧美精品中文字幕一区| 午夜剧场成人观在线视频免费观看| 色999日韩欧美国产| 久久97久久97精品免视看| 久久影院免费观看| 亚洲精品免费网站| 日韩av免费观影| 久久天天躁狠狠躁夜夜躁2014|