简体   繁体   English

java.lang.RuntimeException:尝试在Elastic MapReduce上运行Jar作业时出现java.lang.ClassNotFoundException

[英]java.lang.RuntimeException: java.lang.ClassNotFoundException when trying to run Jar job on Elastic MapReduce

What should I change to fix following error: 我应该更改什么来解决以下错误:

I'm trying to start a job on Elastic Mapreduce, and it crashes every time with message: 我正在尝试在Elastic Mapreduce上开始工作,并且每次出现以下消息都会崩溃:

java.lang.RuntimeException: java.lang.ClassNotFoundException: iataho.mapreduce.NewMaxTemperatureMapper
at org.apache.hadoop.conf.Configuration.getClass(Configuration.java:831)
at org.apache.hadoop.mapreduce.JobContext.getMapperClass(JobContext.java:157)
at org.apache.hadoop.mapred.MapTask.runNewMapper(MapTask.java:577)
at org.apache.hadoop.mapred.MapTask.run(MapTask.java:310)
at org.apache.hadoop.mapred.Child.main(Child.java:170)
Caused by: java.lang.ClassNotFoundException: iataho.mapreduce.NewMaxTemperatureMapper
at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:247)
at org.apache.hadoop.conf.Configuration.getClassByName(Configuration.java:778)
at org.apache.hadoop.conf.Configuration.getClass(Configuration.java:829)
... 4 more

The class NewMaxTemperatureMapper is declared and I've checked, it is included in the jar, which is than located at s3. 声明了类NewMaxTemperatureMapper ,我已经检查了它是否包含在jar中,该jar位于s3处。 Here's the code for all app classes: 这是所有应用程序类的代码:

NewMaxTemperature.java: NewMaxTemperature.java:

package iataho.mapreduce;

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;

public class NewMaxTemperature {
/**
 * @param args
 */
public static void main(String[] args) {

    try {
        if (args.length != 2) {
            System.err.println("Usage: NewMaxTemperature <input path> <output path>");
            System.exit(123);
        }
        Job job = new Job();
        job.setJarByClass(NewMaxTemperature.class);
        FileInputFormat.addInputPath(job, new Path(args[0]));
        FileOutputFormat.setOutputPath(job, new Path(args[1]));

        job.setMapperClass(NewMaxTemperatureMapper.class);
        job.setCombinerClass(NewMaxTemperatureReducer.class);
        job.setReducerClass(NewMaxTemperatureReducer.class);

        job.setOutputKeyClass(Text.class);
        job.setOutputValueClass(IntWritable.class);
        System.exit(job.waitForCompletion(true) ? 0 : 1);
    } catch (Exception e) {
        e.printStackTrace();
    }

}

}

NewMaxTemperatureReducer.java: NewMaxTemperatureReducer.java:

package iataho.mapreduce;

import java.io.IOException;

import org.apache.hadoop.io.IntWritable;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.mapreduce.Reducer;

public class NewMaxTemperatureReducer extends Reducer<Text, IntWritable, Text, IntWritable> {
public void reduce(Text key, Iterable<IntWritable> values, 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));
}
}

NewMaxTemperatureMapper.java: NewMaxTemperatureMapper.java:

package iataho.mapreduce;

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 NewMaxTemperatureMapper extends Mapper<LongWritable, Text, Text, IntWritable> {
private static final int    MISSING = 9999;

public void map(LongWritable key, Text value, Context context) throws IOException, InterruptedException {
    String line = value.toString();
    String year = line.substring(15, 19);
    int airTemperature;
    if (line.charAt(87) == '+') { // parseInt doesn't like leading plus
                                    // signs
        airTemperature = Integer.parseInt(line.substring(88, 92));
    } else {
        airTemperature = Integer.parseInt(line.substring(87, 92));
    }
    String quality = line.substring(92, 93);
    if (airTemperature != MISSING && quality.matches("[01459]")) {
        context.write(new Text(year), new IntWritable(airTemperature));
    }
}
}

I've made the jar file with which I'm getting this crash avaliable here: download jar 我已将要获取此崩溃的jar文件制作为此处: 下载jar

Check the jars you are including when executing the application. 执行应用程序时,检查要包括的jar。 Add more info to the question about this please. 请向此问题添加更多信息。

=== ===

Ok. 好。 The problem was that I've used eclipse option "Package libraries into generated JAR". 问题是我使用了eclipse选项“将库打包到生成的JAR中”。 I changed it to "Extract generated libraries into generated JAR", and now it works fine 我将其更改为“将生成的库提取到生成的JAR中”,现在工作正常

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 有关hadoop的问题“java.lang.RuntimeException:java.lang.ClassNotFoundException:” - Question on hadoop “java.lang.RuntimeException: java.lang.ClassNotFoundException: ” hadoop,java.lang.RuntimeException:java.lang.ClassNotFoundException错误 - hadoop, java.lang.RuntimeException: java.lang.ClassNotFoundException error java.lang.RuntimeException: org.apache.nutch.plugin.PluginRuntimeException: java.lang.ClassNotFoundException 当用 nutch 解析时 - java.lang.RuntimeException: org.apache.nutch.plugin.PluginRuntimeException: java.lang.ClassNotFoundException when parsing with nutch java.lang.RuntimeException:无法实例化活动 ComponentInfo{}:java.lang.ClassNotFoundException - java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{}: java.lang.ClassNotFoundException java.lang.RuntimeException:无法实例化接收者:java.lang.ClassNotFoundException - java.lang.RuntimeException: Unable to instantiate receiver : java.lang.ClassNotFoundException 错误:java.lang.RuntimeException:java.lang.ClassNotFoundException:类WordCountExample $ Map未找到 - Error: java.lang.RuntimeException: java.lang.ClassNotFoundException: Class WordCountExample$Map not found java.lang.RuntimeException:java.lang.ClassNotFoundException:com.coremedia.iso.boxes.mdat.MediaDataBox - java.lang.RuntimeException: java.lang.ClassNotFoundException: com.coremedia.iso.boxes.mdat.MediaDataBox java.lang.RuntimeException:无法实例化应用程序,java.lang.ClassNotFoundException: - java.lang.RuntimeException: Unable to instantiate application, java.lang.ClassNotFoundException: java.lang.RuntimeException:java.lang.ClassNotFoundException: <org.objectweb.asm.ClassWriter.getCommonSuperClass(Unknown Source)> - java.lang.RuntimeException: java.lang.ClassNotFoundException: <org.objectweb.asm.ClassWriter.getCommonSuperClass(Unknown Source)> java.lang.RuntimeException:无法实例化活动ComponentInfo {...}:java.lang.ClassNotFoundException:未找到类 - java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{…}: java.lang.ClassNotFoundException: Didn't find class
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM