1

我对 Hadoop 很陌生。我遵循了有关如何在 hadoop 中创建字数统计程序的基本教程。一切都很好。我尝试创建自己的 map reduce,并将其放在单独的 jar 文件中。当我尝试运行该程序时,它给了我这个错误:

shean@ubuntu-PC:~/hadoop/bin$ hadoop jar ../weather.jar weather.Weather /user/hadoop/weather_log_sample.txt /user/hadoop/output
Warning: $HADOOP_HOME is deprecated.

Exception in thread "main" java.lang.NoClassDefFoundError: org/myorg/WordCount
    at weather.Weather.main(Weather.java:45)
    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:616)
    at org.apache.hadoop.util.RunJar.main(RunJar.java:156)
Caused by: java.lang.ClassNotFoundException: org.myorg.WordCount
    at java.net.URLClassLoader$1.run(URLClassLoader.java:217)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
    ... 6 more

但问题是,它正在寻找 WordCount 类......

4

2 回答 2

1

如果我没记错的话,你错过了罐子 wordcount.jar。请将它添加到build path.

于 2013-04-08T14:36:49.567 回答
0

我的建议:你把“包”路径先去掉。这使得不报告 NoClassDefFoundError 错误更容易。javac 编译时间:javac-classpath "$HADOOP_HOME/hadoop-core-1.2.0.jar: $HADOOP_HOME/lib/commons-cli-1.2.jar"-d。/ 天气

ltianmin@gmail.com

于 2013-07-14T08:50:54.750 回答