在MapReduce作业中找不到的类

时间:2015-04-08 23:48:59

标签: hadoop mapreduce avro

我有一个mapreduce作业,它将avro文件作为输入。我将它与所有必需的库(jar库文件)一起导出到jar文件中。我有2个不同的集群,一个是HDInsight模拟器,另一个是HDP沙箱。它在HDP沙箱上工作正常,但它在HDInsight模拟器上出错,无法找到AvroInputFormat类。我尝试使用-libjar选项运行该作业,但它没有帮助。以下是错误消息:

Error: java.lang.RuntimeException: java.lang.RuntimeException: java.lang.ClassNotFoundException: Class org.apache.avro.mapred.AvroInputFormat not found
    at org.apache.hadoop.conf.Configuration.getClass(Configuration.java:1927)
    at org.apache.hadoop.mapred.JobConf.getInputFormat(JobConf.java:686)
    at org.apache.hadoop.mapred.MapTask$TrackedRecordReader.<init>(MapTask.java:168)
    at org.apache.hadoop.mapred.MapTask.runOldMapper(MapTask.java:409)
    at org.apache.hadoop.mapred.MapTask.run(MapTask.java:342)
    at org.apache.hadoop.mapred.YarnChild$2.run(YarnChild.java:167)
    at java.security.AccessController.doPrivileged(Native Method)
    at javax.security.auth.Subject.doAs(Subject.java:415)
    at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1594)
    at org.apache.hadoop.mapred.YarnChild.main(YarnChild.java:162)
Caused by: java.lang.RuntimeException: java.lang.ClassNotFoundException: Class org.apache.avro.mapred.AvroInputFormat not found
    at org.apache.hadoop.conf.Configuration.getClass(Configuration.java:1895)
    at org.apache.hadoop.conf.Configuration.getClass(Configuration.java:1919)
    ... 9 more
Caused by: java.lang.ClassNotFoundException: Class org.apache.avro.mapred.AvroInputFormat not found
    at org.apache.hadoop.conf.Configuration.getClassByName(Configuration.java:1801)
    at org.apache.hadoop.conf.Configuration.getClass(Configuration.java:1893)
    ... 10 more

这看起来很糟糕,因为它在一个集群上运行良好!有谁知道会出现什么问题?

0 个答案:

没有答案