2016-05-12 12 views
0

ファイルを作成し、10,20,220,228のようないくつかの数値を追加しました。このファイルを以下のようなマッパー関数内で読み込み、数値がAmicableであるかどうかを確認します。しかし、クラスファイルをコンパイルしてjarを構築した後、出力ファイルの中には何もありません。Hadoop MapReduceは出力を書きません

public class FriendlyNumbers { 

    public static void main(String[] args) throws Exception { 
     Configuration conf = new Configuration(); 
     Job job = Job.getInstance(conf, "befriended numbers"); 
     job.setJarByClass(FriendlyNumbers.class); 
     job.setMapperClass(FriendlyNumberMapper.class); 
//  job.setCombinerClass(IntSumReducer.class); 
     job.setReducerClass(FriendlyNumberKeywordReducer.class); 

     job.setMapOutputKeyClass(IntWritable.class); 
     job.setMapOutputValueClass(NumberCouple.class); 
     job.setOutputKeyClass(IntWritable.class); 
     job.setOutputValueClass(IntWritable.class); 

     FileInputFormat.setInputPaths(job, new Path(args[0])); 
     FileOutputFormat.setOutputPath(job, new Path(args[1])); 
     System.exit(job.waitForCompletion(true) ? 0 : 1); 
    } 
} 

class FriendlyNumberMapper extends Mapper<Object, Text, IntWritable, NumberCouple> { 

    // process all the input data 
    // the data come's from the file file0 

    private IntWritable number = new IntWritable(); // number from file 
    private IntWritable sum = new IntWritable(); // number from calculateSum() 
    private NumberCouple numberCouple = new NumberCouple(); 

    public void map(Object key, Text value, Context context) throws IOException, InterruptedException { 

     StringTokenizer numberTokens = new StringTokenizer(value.toString()); 

     // loop trough all given numbers 
     while (numberTokens.hasMoreTokens()) { 

      int parsedNumberToken = Integer.parseInt(numberTokens.nextToken()); 
      int calculatedSum = calculateSum(parsedNumberToken); 

      // set stuff 
      number.set(parsedNumberToken); 
      sum.set(calculatedSum); 
      numberCouple.set(number, sum); 

      context.write(sum, numberCouple); 

      if (number.get() != sum.get()) { 
       context.write(number, numberCouple); 
      } 
     } 
    } 

    // the actual sum to check if a number is amicable 
    public int calculateSum(int number) { 
     int sum = 0; 

     for (int i = 1; i <= number/2; i++) { 
      if (number % i == 0) { 
       sum += i; 
      } 
     } 
     return sum; 
    } 
} 

class FriendlyNumberKeywordReducer extends Reducer<IntWritable, NumberCouple, IntWritable, IntWritable> { 

    // combine data 
    // in this case: get only the befriended numbers and remove others 

    public void reduce(IntWritable key, Iterable<NumberCouple> values, Context context) throws IOException, InterruptedException { 
     // 
    } 
} 

class NumberCouple implements WritableComparable<NumberCouple> { 

    private IntWritable number; 
    private IntWritable sum; 

    public NumberCouple() { 
     set(new IntWritable(), new IntWritable()); 
    } 

    public NumberCouple(NumberCouple couple) { 
     set(new IntWritable(couple.number.get()), new IntWritable(couple.sum.get())); 
    } 

    public NumberCouple(int number, int sum) { 
     set(new IntWritable(number), new IntWritable(sum)); 
    } 

    public void set(IntWritable number, IntWritable sum) { 
     this.number = number; 
     this.sum = sum; 
    } 

    public IntWritable getNumber() { 
     return this.number; 
    } 

    public IntWritable getSum() { 
     return this.sum; 
    } 

    @Override 
    public void write(DataOutput out) throws IOException { 
     number.write(out); 
     sum.write(out); 
    } 

    @Override 
    public void readFields(DataInput in) throws IOException { 
     number.readFields(in); 
     sum.readFields(in); 
    } 

    @Override 
    public int compareTo(NumberCouple o) { 
     return number.compareTo(o.number); 
    } 
} 
+0

あなたのreduceメソッドの実装はどこですか? –

+0

この時点でマッパーだけを使用すると必要ですか? – CodeWhisperer

+0

答えを確認してください、numReduceTaskを0に設定する必要があります。 –

答えて

2

あなたは「0」にnumReduceTaskを設定していないので、減速に移動し、減らすタスクを実行しようとしますので。

マップ専用ジョブを実行する場合は、numReduceTaskを "0"に設定します。 ReducerClassを設定する必要はありません。ドライバクラスで次のように使用します。

Job job = Job.getInstance(conf, "befriended numbers"); 

// Set this property to Zero to run map-only job 
job.setNumReduceTasks(0); 

job.setJarByClass(FriendlyNumbers.class); 
job.setMapperClass(FriendlyNumberMapper.class); 
job.setCombinerClass(IntSumReducer.class); 
job.setMapOutputKeyClass(IntWritable.class); 
job.setMapOutputValueClass(NumberCouple.class); 
job.setOutputKeyClass(IntWritable.class); 
job.setOutputValueClass(IntWritable.class); 
+0

あなたは私の一日を保存しました! – CodeWhisperer

関連する問題