0

こんにちは、これは Hadoop を使用した最初のプログラムで、wordcount プログラムを修正しました。このプログラムを実行できません。マップ出力とリデューサー入力を に変更しました<text text>。入力ファイルには としてレコードが含まれていemail gender age 21ます。実行がハングアップし、 が表示されMap 100% Reduce 100%ます。

//MAPPER
public class WordMapper extends MapReduceBase implements
    Mapper<LongWritable, Text, Text, Text> {

  @Override
  public void map(LongWritable key, Text value,
      OutputCollector<Text, Text> output, Reporter reporter)
      throws IOException {
    String s = value.toString();
    String s1;
    Matcher m2;
    FileSplit filesplit = (FileSplit) reporter.getInputSplit();
    String fileName = filesplit.getPath().getName();

    Pattern p1 = Pattern.compile("\\s+email\\s+gender\\s+age\\s+(\\S+)$");
    m2=p1.matcher(s);
    if (m2.find()){
        s1 = m2.replaceFirst("omitted");
        output.collect(new Text(s1), new Text(fileName));
    }
  }
}

    //REDUCER
public class SumReducer extends MapReduceBase implements
    Reducer<Text, Text, Text, IntWritable> {

  @Override
  public void reduce(Text key, Iterator<Text> values,
      OutputCollector<Text, IntWritable> output, Reporter reporter)
      throws IOException {

    int cliCount = 0;
    while (values.hasNext()) {
      cliCount += 1;
    }
    output.collect(key, new IntWritable(cliCount));
  }
}

    //MAIN
public class WordCount extends Configured implements Tool {

  @Override
  public int run(String[] args) throws Exception {

    if (args.length != 2) {
      System.out.printf(
          "Usage: %s [generic options] <input dir> <output dir>\n", getClass()
              .getSimpleName());
      ToolRunner.printGenericCommandUsage(System.out);
      return -1;
    }

    JobConf conf = new JobConf(getConf(), WordCount.class);
    conf.setJobName(this.getClass().getName());

    FileInputFormat.setInputPaths(conf, new Path(args[0]));
    FileOutputFormat.setOutputPath(conf, new Path(args[1]));

    conf.setMapperClass(WordMapper.class);
    conf.setReducerClass(SumReducer.class);

    conf.setMapOutputKeyClass(Text.class);
    conf.setMapOutputValueClass(Text.class);

    conf.setOutputKeyClass(Text.class);
    conf.setOutputValueClass(IntWritable.class);

    JobClient.runJob(conf);
    return 0;
  }

  public static void main(String[] args) throws Exception {
    int exitCode = ToolRunner.run(new WordCount(), args);
    System.exit(exitCode);
  }
}

更新: _log フォルダー内の.xmlファイルのみが存在します

私はプログラムを実行し続けましたが、hadoop はそれを殺しました。

3/06/19 15:02:47 INFO mapred.JobClient:     Total committed heap usage (bytes)=258875392
13/06/19 15:02:47 INFO mapred.JobClient:   org.apache.hadoop.mapreduce.lib.input.FileInputFormatCounter
13/06/19 15:02:47 INFO mapred.JobClient:     BYTES_READ=26
13/06/19 15:02:47 INFO mapred.JobClient: Job Failed: NA
Exception in thread "main" java.io.IOException: Job failed!
    at org.apache.hadoop.mapred.JobClient.runJob(JobClient.java:1322)
    at WordCount.run(WordCount.java:41)
    at org.apache.hadoop.util.ToolRunner.run(ToolRunner.java:70)
    at org.apache.hadoop.util.ToolRunner.run(ToolRunner.java:84)
    at WordCount.main(WordCount.java:46)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:601)
    at org.apache.hadoop.util.RunJar.main(RunJar.java:208)
4

1 に答える 1