错误:java.lang.classcastexception:wordcounttest.wordcounttest无法转换为org.apache.hadoop.mapreduce.mapper

e4eetjau  于 2021-05-29  发布在  Hadoop
关注(0)|答案(1)|浏览(345)

我是一个初学者试图学习Map减少使用java。我正在尝试使用oozie协调器运行单词计数示例。我在选角时出错了。如果有人帮我解决这个错误就太好了。
“错误:java.lang.classcastexception:wordcounttest.wordcounttest无法转换为org.apache.hadoop.mapreduce.mapper”
以下是我的wordcounttest.java代码段:

package wordCountTest;

import java.io.IOException;
import java.util.StringTokenizer;
import org.apache.hadoop.conf.Configuration;
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.Mapper;
import org.apache.hadoop.mapreduce.Reducer;
import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;
import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;

public class WordCountTest {
 public static class TokenizerMapper
            extends Mapper<Object, Text, Text, IntWritable>{
  private final static IntWritable one = new IntWritable(1);
  private Text word = new Text();
  public void map(Object key, Text value, Context context
        ) throws IOException, InterruptedException {
   StringTokenizer itr = new StringTokenizer(value.toString());
   while (itr.hasMoreTokens()) {
    word.set(itr.nextToken());
    context.write(word, one);
   }
  }
 }
 public static class IntSumReducer
            extends Reducer<Text,IntWritable,Text,IntWritable> {
  private IntWritable result = new IntWritable();    
  public void reduce(Text key, Iterable<IntWritable> values,
                           Context context
        ) throws IOException, InterruptedException {
   int sum = 0;
   for (IntWritable val : values) {
    sum += val.get();
   }
   result.set(sum);
   context.write(key, result);
  }
 }
 public static void main(String[] args) throws Exception {
  Configuration conf = new Configuration();
  Job job = new Job(conf,"WordCount");
  job.setJarByClass(WordCountTest.class);
  job.setMapperClass(TokenizerMapper.class);
  job.setCombinerClass(IntSumReducer.class);
  job.setReducerClass(IntSumReducer.class);
  job.setOutputKeyClass(Text.class);
  job.setOutputValueClass(IntWritable.class);
  FileInputFormat.addInputPath(job, new Path(args[0]));
  FileOutputFormat.setOutputPath(job, new Path(args[1]));
  System.exit(job.waitForCompletion(true) ? 0 : 1);
 }
}

另外,我的workflow.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<workflow-app xmlns="uri:oozie:workflow:0.1" name="map-reduce-wf">
 <start to="mr-node" />
 <action name="mr-node">
  <map-reduce>
   <job-tracker>${jobTracker}</job-tracker>
   <name-node>${nameNode}</name-node>
   <configuration>
    <property>
     <name>mapred.mapper.new-api</name>
     <value>true</value>
    </property>
    <property>
     <name>mapred.reducer.new-api</name>
     <value>true</value>
    </property>
    <property>
     <name>mapred.job.queue.name</name>
     <value>${queueName}</value>
    </property>
    <property>
     <name>mapreduce.map.class</name>
     <value>wordCountTest.WordCountTest.TokenizerMapper</value>
    </property>
    <property>
     <name>mapreduce.reduce.class</name>
     <value>wordCountTest.WordCountTest.IntSumReducer</value>
    </property>
    <property>
     <name>mapreduce.combine.class</name>
     <value>wordCountTestEmr.WordCountTest.IntSumReducer</value>
    </property>
    <property>
     <name>mapred.output.key.class</name>
     <value>org.apache.hadoop.io.Text</value>
    </property>
    <property>
     <name>mapred.output.value.class</name>
     <value>org.apache.hadoop.io.IntWritable</value>
    </property>
    <property>
     <name>mapred.input.dir</name>
     <value>/user/ahegde/testemr/InputData/</value>
    </property>
    <property>
     <name>mapred.output.dir</name>
     <value>/user/ahegde/testemr/OutputData</value>
    </property>
   </configuration>
  </map-reduce>
 <ok to="end" />
 <error to="fail" />
 </action>
  <kill name="fail">
   <message>Map/Reduce failed, error message[${wf:errorMessage(wf:lastErrorNode())}]</message>
  </kill>
  <end name="end" />
 </workflow-app>
9q78igpj

9q78igpj1#

您可能需要更改oozie配置,因为这些是内部静态类:

<property>
    <name>mapreduce.map.class</name>
    <value>wordCountTest.WordCountTest$TokenizerMapper</value>
</property>

变化是最重要的 .$ .

相关问题