java - Hadoop setMapperClass和SetReducerClass无法正常工作?

标签 java hadoop mapreduce

我是Hadoop的新手,我有3个单独的文件,分别包含map,reduce和mapreduce代码.mapper和reducer文件已编译,但主类抛出的setmapperclass和setreducerclass方法中找不到符号错误。这是main的代码:

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;
import org.apache.hadoop.mapreduce.Mapper;
public class MaxTemperature {
public static void main(String[] args) throws Exception {
if (args.length != 2) {
System.err.println("Usage: MaxTemperature <input path> <output path>");
System.exit(-1);
}
Job job = new Job();
job.setJarByClass(MaxTemperature.class);
job.setJobName("Max temperature");
FileInputFormat.addInputPath(job, new Path(args[0]));
FileOutputFormat.setOutputPath(job, new Path(args[1]));
job.setMapperClass(MaxTemperatureMapper.class); //error cannot find symbol
job.setReducerClass(MaxTemperatureReducer.class); //error cannot find symbol
job.setOutputKeyClass(Text.class);
job.setOutputValueClass(IntWritable.class);
}}

hadoop的使用版本是2.5.1,我使用
hdfs com.sun.tools.javac.Main /usr/local/hadoop/share/hadoop/mapreduce/MaxTemperature.java

我使用了相同的命令来编译mapper和reducer程序。

最佳答案

您可以将所有三个文件一起编译,如下所示:

javac -cp hadoop-common-0.21.0.jar:hadoop-core-1.1.2.jar:commons-cli-1.3.1.jar:com.google.guava_1.6.0.jar:hadoop-mapred-0.21.0 .jar FacebookCount.java FacebookMapper.java FacebookReducer.java -d / usr / local / com / subu /

关于java - Hadoop setMapperClass和SetReducerClass无法正常工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26446903/

相关文章:

java - 在 JAVA 中使用 Apache POI 和 iText 从 Word (DOC) 创建 PDF

java - 用星号替换元音

datetime - hive :在 “yyyy-MM-dd' T'HH:mm:ss.SSS'Z'中转换缺少日期的字符串日期时间

linux - Hadoop启动-dfs脚本调试

python - 将用于 mapreduce 的 Python 脚本传递给 HBase

java - 在 Java 中反转一对链表

java - 分布式服务器的拉与推

java - hive 计数 * 内存不足

perl - 为什么我的 reducer 出现故障? (Hadoop)

hadoop - 在 PIG 中将 Chararry 类型转换为 double 的异常