我使用Apache Spark创建了一个小应用程序,当我在本地运行应用程序时一切正常。但是当我将它提交到一个由6个节点组成的集群时,出现了FileNotFoundException,因为它找不到输入文件。
这是我的小应用程序。
def main (args: Array[String]) {
val sparkContext = new SparkContext(new SparkConf())
val tweets = sparkContext.textFile(args(0))
tweets.map { line => (line, LanguageDetector.create().detect(line)) }
.saveAsTextFile("/data/detected")
}
我用以下命令提交申请:
/opt/spark-1.0.2-bin-hadoop2/bin/spark-submit --class YarnTest --master spark://luthor-v1:7077 lang_detect.jar twitter_data
提交后,我收到了以下异常信息:
Exception in thread "main" org.apache.spark.SparkException: Job aborted due to stage failure: Task 0.0:1 failed 4 times, most recent failure: Exception failure in TID 6 on host luthor-v5: java.io.FileNotFoundException: File file:/opt/bb/twitter_data does not exist
文件肯定在那里,jar包和文件在同一个目录中,可以解析完整路径。
提前感谢。