Could not find or load main class org.apache.spark.deploy.yarn.ApplicationMaster

问题描述

场景:
在小海豚里面调度Spark任务是出现这个问题。
spark 3.0.1
yarn:3.1.1
日志:

Container exited with a non-zero exit code 1. Error file: prelaunch.err.
	Last 4096 bytes of prelaunch.err :
	Last 4096 bytes of stderr :
	Error: Could not find or load main class org.apache.spark.deploy.yarn.ApplicationMaster

解决方案:

1.配置 spark.yarn.jars

  • 1 上传jars到Hdfs
hadoop fs -mkdir -p  /spark-yarn/jars
 hadoop fs -put $SPARK_HOME/jars/* /spark-yarn/jars/
  • 2 修改spark-defaults.conf
spark.yarn.jars hdfs://hadoop218:8020/spark-yarn/jars/*.jar

这个是网上的大多数的解决方案,但是我配置了,还是出现上述的错误。于是我找到了下面的解决方式

2.配置 spark.yarn.archive

针对1不起作用的情况

  • 1打包jar
cd  $SPARK_HOME/jars/

zip -q -r spark_jars_.zip *

hadoop fs -mkdir /spark-yarn/zip

hadoop fs -put spark_jars.zip /spark-yarn/zip/
  • 2修改修改spark-defaults.conf
spark.yarn.archive hdfs://hadoop218:8020/spark-yarn/zip/spark_jars.zip

参数分析:

Spark官网介绍:
在这里插入图片描述

使用yarn的方式提交spark应用时,在没有配置spark.yarn.archive或者spark.yarn.jars时, 看到输出的日志在输出Neither spark.yarn.jars nor spark.yarn.archive is set;一段指令后,会看到不停地上传本地jar到HDFS上,内容如下,这个过程会非常耗时。可以通过在spark-defaults.conf配置里添加spark.yarn.archive或spark.yarn.jars来缩小spark应用的启动时间

spark.yarn.archive有个说明是,说如果两个参数都配置,应用程序会优先使用 spark.yarn.archive会代替 spark.yarn.jars 在所有容器中使用打包文件。

同样这是一项优化手段,配置spark.yarn.archive并且上传了程序所有的依赖jar的方式能减少资源的上传。


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,错误信息"Error: Could not find or load main class fs"可能是由于缺少或无法加载主类fs导致的。然而,在提供的引用内容中没有找到与此错误相关的具体解决方法。建议您检查您的代码或配置文件中是否正确指定了主类fs,并确保该类在您的环境中可用。如果问题仍然存在,您可以尝试在相关的配置文件或命令中进行进一步的调试和排查。 #### 引用[.reference_title] - *1* [Error: Could not find or load main class org.apache.hadoop.fs.FsShell](https://blog.csdn.net/xuezhisdc/article/details/77565864)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [hbase 启动 Error: Could not find or load main class org.apache.hadoop.hbase.util.HBaseConfTool](https://blog.csdn.net/aagwpsh7758/article/details/101957177)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Error: Could not find or load main class org.apache.spark.deploy.yarn.ApplicationMaster](https://blog.csdn.net/Alex_Sheng_Sea/article/details/86689148)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值