Hadoop 异常-java.lang.IllegalArgumentException:在Mahout中找不到标签

Hadoop 异常-java.lang.IllegalArgumentException:在Mahout中找不到标签,hadoop,amazon-ec2,classification,mahout,Hadoop,Amazon Ec2,Classification,Mahout,我正在运行以下命令 /mahout trainnb -i ${WORK_DIR}/20news-train-vectors -el -o ${WORK_DIR}/model -li ${WORK_DIR}/labelindex -ow ./mahout testnb -i ${WORK_DIR}/20news-test-vectors -m ${WORK_DIR}/model -l ${WORK_DIR}/labelindex

我正在运行以下命令

/mahout trainnb 
    -i ${WORK_DIR}/20news-train-vectors -el 
    -o ${WORK_DIR}/model 
    -li ${WORK_DIR}/labelindex 
    -ow

./mahout testnb 
    -i ${WORK_DIR}/20news-test-vectors
    -m ${WORK_DIR}/model 
    -l ${WORK_DIR}/labelindex\
    -ow -o ${WORK_DIR}/20news-testing
在运行最后一个命令时,我能够将map任务运行到100%,但在reduce任务中,我得到以下错误:

Exception in thread "main" java.lang.IllegalArgumentException: Label not found: 10002
        at com.google.common.base.Preconditions.checkArgument(Preconditions.java:88)
        at org.apache.mahout.classifier.ConfusionMatrix.getCount(ConfusionMatrix.java:182)
        at org.apache.mahout.classifier.ConfusionMatrix.incrementCount(ConfusionMatrix.java:                205)
        at org.apache.mahout.classifier.ConfusionMatrix.incrementCount(ConfusionMatrix.java:                209)
        at org.apache.mahout.classifier.ConfusionMatrix.addInstance(ConfusionMatrix.java:173                )
        at org.apache.mahout.classifier.ResultAnalyzer.addInstance(ResultAnalyzer.java:70)
        at org.apache.mahout.classifier.naivebayes.test.TestNaiveBayesDriver.analyzeResults(                TestNaiveBayesDriver.java:160)
        at org.apache.mahout.classifier.naivebayes.test.TestNaiveBayesDriver.run(TestNaiveBa                yesDriver.java:125)
        at org.apache.hadoop.util.ToolRunner.run(ToolRunner.java:70)
        at org.apache.mahout.classifier.naivebayes.test.TestNaiveBayesDriver.main(TestNaiveB                ayesDriver.java:66)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java                :43)
        at java.lang.reflect.Method.invoke(Method.java:606)
        at org.apache.hadoop.util.ProgramDriver$ProgramDescription.invoke(ProgramDriver.java                :72)
        at org.apache.hadoop.util.ProgramDriver.run(ProgramDriver.java:144)
        at org.apache.hadoop.util.ProgramDriver.driver(ProgramDriver.java:152)
        at org.apache.mahout.driver.MahoutDriver.main(MahoutDriver.java:195)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java                :43)
        at java.lang.reflect.Method.invoke(Method.java:606)
        at org.apache.hadoop.util.RunJar.main(RunJar.java:212)
我遵循的是labelindex上的示例,还尝试了seqdumper,可以看到其中的键和值

我使用的是Hadoop2.2、Mahout1.0,整个环境都是在AmazonEC2上设置的


请帮帮我。我做错什么了吗?

我认为mahout与您的hadoop版本不兼容,您应该下载hadoop的1.1.0或1.2.0版本。
这可能会解决您的问题。

我想您的文件在本地。我也有这个问题,当我将文件更改为HDFS时,我解决了这个问题。你能解释一下你为什么这样想吗?