我是Hadoop的新手,我正在阅读“权威指南”一书。
在ch02中有一个简单的hadoop示例,它有一个mapper,一个reducer和一个带main函数的类。
正如书中所说,我必须使用
% export HADOOP_CLASSPATH=hadoop-examples.jar
% hadoop MaxTemperature input/ncdc/sample.txt output
运行代码。 MaxTemperature是具有main方法的类,后跟输入和输出路径。
当我运行上面的命令时,我得到了异常:
Exception in thread "main" java.lang.NoClassDefFoundError: MaxTemperature
Caused by: java.lang.ClassNotFoundException: MaxTemperature
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 sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
Could not find the main class: MaxTemperature. Program will exit.
我发现我没有.class文件,所以我尝试使用javac来编译java文件。然后它给了我错误说不能找到来自Hadoop的所有类。
我转向eclipse,用hadoop构建路径创建了一个项目。它工作得很好,我在eclipse项目的bin文件夹中找到了.class文件。到这个时候,因为我得到了那些.class文件,我可以使用:
% hadoop MaxTemperature input/ncdc/sample.txt output
我的问题是:
如何正确使用配置hadoop类路径来使用javac编译java文件并获取.class文件?
(我使用hadoop classpath
并发现hadoop_classpath太长了。我是否必须将类路径设置为那么长?)
谢谢:)
答案 0 :(得分:0)
javac -classpath解决所有问题!!!