从远程系统提交mapreduce作业时出现异常

时间:2013-10-28 13:34:22

标签: java linux hadoop mapreduce remote-server

我从远程系统提交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没有。

**请帮忙.. **

1 个答案:

答案 0 :(得分:0)

实际上这是我的配置错误:

我在 mapred-site.xml

中错过了 mapred.local.dir 属性

 

<property> <name>mapred.local.dir</name> <value>/usr/local/hadoop-1.0.3/local</value> </property>