Spark执行失败-SparkContext did not initialize after waiting for 100000 ms

本文介绍了一种在使用SparkContext时遇到的初始化超时错误,并详细解释了解决方案:通过将SparkContext的创建从class中抽离到object中来避免这一问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

执行其刚写完的项目进行测试时,遇到以下问题
ERROR yarn.ApplicationMaster: SparkContext did not initialize after waiting for 100000 ms. Please check earlier log output for errors. Failing the application

检查代码(Scala),发现其将SparkContext的创建写在了class中,并且其之前还有很多其他的业务逻辑代码

object SparkContextTest extends Serializable {
  def main(args: Array[String]): Unit = {
    try {
      new SparkContextTest().run()
    } catch {
      case ex: Throwable =>
        println(ex)
        sys.exit(1)
    }
  }
}

class SparkContextTest() extends Serializable {

  def run(): Unit = {
    // 各种业务逻辑代码
    val conf = new SparkConf()
      .setAppName("SparkContextTest")

    val sc = new SparkContext(conf)
    val test = sc.longAccumulator
  }
}

将SparkContext的创建抽取到object中,如下所示

object SparkContextTest extends Serializable {
  def main(args: Array[String]): Unit = {
    val conf = new SparkConf()
      .setAppName("SparkContextTest")

    val sc = new SparkContext(conf)

    try {
      new SparkContextTest(sc).run()
    } catch {
      case ex: Throwable =>
        println(ex)
        sys.exit(1)
    }
  }
}

class SparkContextTest(sc: SparkContext) extends Serializable {

  def run(): Unit = {
    // 各种业务逻辑代码
    val test = sc.longAccumulator
  }
}

可以正常执行,没有再出现类似问题

这主要是因为在进行spark-submit后,程序在yarn上处于accept状态,而长时间没有进行spark初始化,则会在超时后报错

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值