如何在使用hadoop命令运行它之前获取.class文件?

1aaf6o9v  于 2021-06-03  发布在  Hadoop
关注(0)|答案(1)|浏览(295)

我是hadoop的新手,正在阅读“权威指南”一书。
在ch02中有一个简单的hadoop示例,它有一个Map器、一个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的类路径太长了。我必须把类路径设置为那么长吗?)
谢谢:)

7nbnzgx9

7nbnzgx91#

javac-classpath解决了所有的问题!!!

相关问题