Spark on YARN

Spark on YARN 基本概念

  1. YARN(Yet Another Resource Negotiator): 是 Hadoop 生态系统的一部分,用于集群资源管理和作业调度。
  2. Spark on YARN: 是指在 YARN 上运行 Spark 应用程序,利用 YARN 来管理资源和调度任务。

Spark on YARN 的运行模式

  1. Cluster 模式: 在这种模式下,Spark Driver 运行在 YARN 集群的一个节点上,适合长时间运行的作业。
  2. Client 模式: 在这种模式下,Spark Driver 运行在提交应用程序的客户端机器上,适合开发和调试。

Spark on YARN 的配置

为了在 YARN 上运行 Spark,需要进行一些配置:

  1. yarn-site.xml: 这是 YARN 的配置文件,通常位于 Hadoop 配置目录中。你需要确保这个文件在 Spark 配置中可以访问。

  2. spark-env.sh: 这是 Spark 的环境配置文件。你需要设置一些环境变量,比如 SPARK_HOME, HADOOP_CONF_DIR 等。

  3. spark-defaults.conf: 这是 Spark 的默认配置文件,可以在这里设置 Spark 作业的一些默认参数,比如 master URL(yarn)、deploy mode(client 或 cluster)、executor 内存等。

提交 Spark 作业到 YARN

可以使用 spark-submit 命令将 Spark 作业提交到 YARN 上运行:

spark-submit \
  --class <main-class> \
  --master yarn \
  --deploy-mode cluster \
  --executor-memory 4g \
  --executor-cores 2 \
  <application-jar> \
  [application-arguments]

注意事项

  1. 资源配置: 根据作业的需求合理配置 executor 内存和核心数量,避免资源浪费或不足。
  2. 日志查看: 在 YARN 上运行的 Spark 作业的日志可以通过 YARN ResourceManager 或 YARN History Server 查看,帮助你调试和优化作业。
  3. 依赖管理: 如果你的 Spark 作业有外部依赖库,需要确保这些库可以被 YARN 节点访问,可以通过 --jars 参数指定依赖库路径。

例子

假设你有一个 Spark 应用程序,主类是 com.example.MyApp,打包后的 jar 文件名是 myapp.jar,你可以用以下命令提交到 YARN 上运行:

spark-submit \
  --class com.example.MyApp \
  --master yarn \
  --deploy-mode cluster \
  --executor-memory 4g \
  --executor-cores 2 \
  myapp.jar

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spark on YARN是一种常用的Spark运行模式,它可以在Hadoop YARN集群上运行。Spark on YARN支持两种提交任务的方式,即YARN client模式和YARN cluster模式。在YARN client模式下,Spark驱动程序运行在客户端上,而在YARN cluster模式下,Spark驱动程序运行在YARN集群上。 在使用Spark on YARN时,可以使用以下命令提交作业: ``` ./spark-submit --master yarn --deploy-mode cluster --class org.apache.spark.examples.SparkPi ../lib/spark-examples-xx.jar 100 ``` 这个命令将以YARN cluster模式提交一个Spark作业,其中`--master yarn`表示使用YARN作为Spark的主节点,`--deploy-mode cluster`表示以集群模式运行作业,`--class org.apache.spark.examples.SparkPi`指定了作业的入口类,`../lib/spark-examples-xx.jar`是作业的jar包路径,`100`是作业的参数。 另外,还可以使用以下命令以YARN client模式提交作业: ``` ./spark-submit --master yarn-client --class org.apache.spark.examples.SparkPi ../lib/spark-examples-xx.jar 100 ``` 这个命令将以YARN client模式提交一个Spark作业,其中`--master yarn-client`表示使用YARN作为Spark的主节点,并将驱动程序运行在客户端上。 通过以上命令,可以在Spark on YARN上成功提交和运行Spark作业。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* *3* [Spark on Yarn详解](https://blog.csdn.net/WuBoooo/article/details/109479311)[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、付费专栏及课程。

余额充值