运行mapreduce作业时发生IOException

时间:2014-01-06 08:03:19

标签: java hadoop mapreduce

我创建了一个mapreduce作业,用于根据特定时间段计算某些监控信息的平均值。它工作正常。昨天,由于电源故障,hadoop跑步机意外停机。但重新启动后,在运行相同的mapreduce作业时,我遇到以下异常:



    14/01/06 13:16:39 INFO mapred.JobClient: Running job: job_201401060557_0001
    14/01/06 13:16:40 INFO mapred.JobClient:  map 0% reduce 0%
    14/01/06 13:17:00 INFO mapred.JobClient:  map 99% reduce 0%
    14/01/06 13:17:08 INFO mapred.JobClient: Task Id : attempt_201401060557_0001_m_000000_0,

          Status : FAILED
 org.apache.hadoop.ipc.RemoteException: java.io.IOException: failed to create file  
    /user/root/out1/_temporary/_attempt_201401060557_0001_m_000000_0/hi/101-m-00000 on  
    client 192.168.1.149 either because the filename is invalid or the file exists
    at 
 org.apache.hadoop.hdfs.server.namenode.FSNamesystem.startFileInternal(FSNamesystem.java:1265)
    at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.startFile(FSNamesystem.java:1188)
    at org.apache.hadoop.hdfs.server.namenode.NameNode.create(NameNode.java:628)
    at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.hadoop.ipc.RPC$Server.call(RPC.java:563)
    at org.apache.hadoop.ipc.Server$Handler$1.run(Server.java:1388)
    at org.apache.hadoop.ipc.Server$Handler$1.run(Server.java:1384)
    at java.security.AccessController.doPrivileged(Native Method)
    at javax.security.auth.Subject.doAs(Subject.java:396)
    at     org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1121)
    at org.apache.hadoop.ipc.Server$Handler.run(Server.java:1382)

其中 / usr / root / out1 是此作业的输出路径,在运行作业之前已清除。 我也多次关闭这台机器,但我没有得到这样的例外。我老了,我的数据丢了! 它也是一个单节点集群。

希望你的帮助

1 个答案:

答案 0 :(得分:0)

对不起,这是我的错。我设置了错误的组合器!当我纠正它时,它起作用了。