// Java言語のお約束 & hadoopクラスの指定 package org.myorg; import java.io.IOException; import java.util.*; import org.apache.hadoop.fs.Path; import org.apache.hadoop.conf.*; import org.apache.hadoop.io.*; import org.apache.hadoop.mapred.*; import org.apache.hadoop.util.*; // WordCountクラス public class WordCount { // Mapクラス public static class Map extends MapReduceBase implements Mapper { // Map関数の出力の「1」 private final static IntWritable one = new IntWritable(1); private Text word = new Text(); // Map関数 public void map(LongWritable key, Text value, OutputCollector output, Reporter reporter) throws IOException { // Map関数への入力を変数lineに代入 String line = value.toString(); // lineの内容をスペース区切りで分割するStringTokenizerクラスの宣言 StringTokenizer tokenizer = new StringTokenizer(line); // lineに取り出せる単語が残っている間はループ while (tokenizer.hasMoreTokens()) { // lineから単語を一つ取り出す (lineの内容が" 0.1245 -0.8251 1.5828 ..." のとき、 // 最初に0.1245が、次に-0.8251といった具合に順に取りだされる) word.set(tokenizer.nextToken()); // KeyValueペアを出力 (key, value)=(単語、「1」) output.collect(word, one); } } } // Reduceクラス public static class Reduce extends MapReduceBase implements Reducer { // Reduce関数 特定のkeyを持つKeyValueペアのvalue値がvaluesに代入されてこの関数が呼び出される public void reduce(Text key, Iterator values, OutputCollector output, Reporter reporter) throws IOException { // 合計を代入する変数sumの宣言・ゼロクリア int sum = 0; // 入力value値群valuesの要素全てについてループを回す while (values.hasNext()) { // sumにvaluesの要素の値を足しこむ sum += values.next().get(); } // KeyValueペアを出力 (key, value)=(key, valueの合計) output.collect(key, new IntWritable(sum)); } } // main関数 プログラムの開始地点 // Map, Reduce関数の指定、入出力フォーマットの指定等 public static void main(String[] args) throws Exception { JobConf conf = new JobConf(WordCount.class); conf.setJobName("wordcount"); conf.setOutputKeyClass(Text.class); conf.setOutputValueClass(IntWritable.class); conf.setMapperClass(Map.class); conf.setCombinerClass(Reduce.class); conf.setReducerClass(Reduce.class); conf.setInputFormat(TextInputFormat.class); conf.setOutputFormat(TextOutputFormat.class); FileInputFormat.setInputPaths(conf, new Path(args[0])); FileOutputFormat.setOutputPath(conf, new Path(args[1])); JobClient.runJob(conf); } }