亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

spark-submit報錯:

標簽:
Spark

原文标题:

spark-submit报错:Application application_1529650293575_0148 finished with failed status

我的原创地址:

2、异常原因

出现该异常场景是spark-submit提交master为yarn cluster,yarn client没有这种问题,原因是因为,在代码里指定了master为local(本地测试用),在spark-submit提交程序时忘记删除了

3、异常再现

代码

package com.dkl.leanring.spark.exceptionimport org.apache.spark.sql.SparkSessionobject YarnClusterDemo {  def main(args: Array[String]): Unit = {    val spark = SparkSession.builder().appName("YarnClusterDemo").master("local").getOrCreate()    val sc = spark.sparkContext    val rdd = sc.parallelize(Seq(1, 2, 3))
    println(rdd.count)

    spark.stop()
  }
}

这段代码在本地是没有问题,输出结果为3,把它打包,然后放在集群上,用spark-submit提交测试一下

4、yarn client

--master yarn 默认的就是client模式,所以用下面的命令

spark-submit --master yarn --class com.dkl.leanring.spark.exception.YarnClusterDemo spark-scala_2.11-1.0.jar

等价于

spark-submit --master yarn --deploy-mode client --class com.dkl.leanring.spark.exception.YarnClusterDemo spark-scala_2.11-1.0.jar

结果也会正常打印出来,因为在代码里指定了master为local所以实际上应该还是用的local,但是没有研究client模式不报错,可能是用的client模式用提交代码的那台机器为Driver,然后再用local模式吧

5、yarn cluster

用下面的命令,即可再现异常

spark-submit --master yarn --deploy-mode cluster --class com.dkl.leanring.spark.exception.YarnClusterDemo spark-scala_2.11-1.0.jar

所以实际用spark-submit提交程序的时候,将master在代码里删掉,然后用命令行--master指定即可

val spark = SparkSession.builder().appName("YarnClusterDemo").getOrCreate()

6、附图

webp

image


webp

image

7、更新:其他情况

在我后面用yarn cluster模式的时候,又碰到了一样的异常信息,检查了一下master没有在代码里指定为local,经过一步步的测试,最后发现,是由于有一行代码读取的本地文件,在yarn client模式的时候,提交程序的那台机器即为Driver,会从Driver的机器上对应的目录找本地文件,所以在yarn client的时候不会报错(Driver有该文件)在yarn cluster会随机选择集群上一个节点作为Driver,那么Driver没有该文件,就会产生异常,而yarn cluster模式返回的异常不很明确,只是返回

Exception in thread "main" org.apache.spark.SparkException: Application application_*** finished with failed status

这样的异常,所以不知道是哪里出错了,可以在代码里加上捕获异常的代码,这样就可以在yarn的日志里看到具体的异常信息了,具体的代码我就不贴了,贴一下捕获异常的

try {      //此处为你的可能产生异常的代码
   } catch {     case e: Exception => println(e)
   }

在加了捕获异常代码后,yarn日志


webp

image



作者:董可伦
链接:https://www.jianshu.com/p/663f7adcb41e


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消