我从远程系统提交mapreduce作业时遇到异常
13/10/28 18:49:52 ERROR security.UserGroupInformation:PriviledgedActionException as:root cause:org.apache.hadoop.mapred.InvalidInputException:输入路径不存在:file:/ F:/ Workspaces / Test / Hadoop的/测试
我的hadoop和mapreduce环境是在linux机器上配置的。我从本地Windows PC提交wordcount作业,如下所示:
public static void main(String[] args) throws Exception {
UserGroupInformation ugi = UserGroupInformation.createRemoteUser("root");
try {
ugi.doAs(new PrivilegedExceptionAction<Void>() {
public Void run() throws Exception {
JobConf conf = new JobConf(MapReduce.class);
conf.set("mapred.job.name", "MyApp");
conf.set("mapred.job.tracker", "192.168.1.149:9001");
conf.set("fs.default.name","hdfs://192.168.1.149:9000");
conf.set("hadoop.job.ugi", "root");
conf.setOutputKeyClass(Text.class);
conf.setOutputValueClass(IntWritable.class);
conf.setMapperClass(Map.class);
conf.setCombinerClass(Reduce.class);
conf.setReducerClass(Reduce.class);
conf.setInputFormat(TextInputFormat.class);
conf.setOutputFormat(TextOutputFormat.class);
FileInputFormat.setInputPaths(conf, new Path("test"));
FileOutputFormat.setOutputPath(conf, new Path("test"));
JobClient.runJob(conf);
return null;
}
});
} catch (Exception e) {
e.printStackTrace();
}
}
其中192.168.1.149是hadoop配置的linux pc。我在那里开始了hadoop,mapreduce服务。此外,测试目录也是使用相同的Java API创建的,它可以工作。但mapreduce没有。
**请帮忙.. **
答案 0 :(得分:0)
实际上这是我的配置错误:
我在 mapred-site.xml
中错过了 mapred.local.dir 属性
<property>
<name>mapred.local.dir</name>
<value>/usr/local/hadoop-1.0.3/local</value>
</property>