如何搭建spark yarn模式的集群

一、基础环境准备
  1. 安装JDK 1.8+
    所有节点需安装JDK并配置环境变量,确保JAVA_HOME正确指向安装路径14。
  2. 部署Hadoop集群
    • 安装Hadoop(推荐3.x版本),配置YARN资源管理器4。

    • yarn-site.xml中启用资源调度:

      XML 复制代码
      <property>  
        <name>yarn.resourcemanager.hostname</name>  
        <value>主节点IP或主机名</value>  
      </property>  

设置HADOOP_HOMEHADOOP_CONF_DIR环境变量4。

  • 安装Spark

    • 下载与Hadoop兼容的Spark版本(如Spark 3.5.5对应Hadoop 3.x)4。

    • 解压至统一目录(如/opt/spark),配置SPARK_HOME环境变量4。

      二、Spark集成YARN配置
    • 修改spark-env.sh
      添加以下配置以关联Hadoop和YARN:

      复制代码

      bashCopy Code

      export JAVA_HOME=/opt/java/jdk8 export HADOOP_HOME=/opt/hadoop/hadoop-3.2.2 export HADOOP_CONF_DIR=$HADOOP_HOME/etc/hadoop export SPARK_DIST_CLASSPATH=$(hadoop classpath) # 动态加载Hadoop类路径:ml-citation{ref="4" data="citationList"}

    • 配置spark-defaults.conf
      指定YARN为资源管理器:

      复制代码

      textCopy Code

      spark.master yarn spark.yarn.jars hdfs:///spark/jars/* # 可选,将Spark依赖上传至HDFS:ml-citation{ref="4,8" data="citationList"}


    三、集群分发与服务启动
    • 同步配置到所有节点
      使用scp或集群管理工具(如Ansible)将配置文件和安装目录分发至所有工作节点4。
    • 启动Hadoop与YARN服务
      • 启动HDFS:start-dfs.sh
      • 启动YARN:start-yarn.sh
        确认ResourceManager和NodeManager进程正常4。

    四、验证集群部署
    • 提交测试任务到YARN
      使用spark-submit提交示例程序:

      复制代码

      bashCopy Code

      spark-submit --class org.apache.spark.examples.SparkPi \ --master yarn \ $SPARK_HOME/examples/jars/spark-examples_2.12-3.5.5.jar 100
      检查YARN Web UI(默认端口8088)中任务状态和日志输出34。

    • 验证资源分配
      确认任务执行后,在YARN监控界面查看资源使用情况(CPU、内存分配)3。


    五、注意事项
    • 版本兼容性
      Spark、Hadoop、Scala版本需严格匹配(如Spark 3.5.5需Scala 2.12.x和Hadoop 3.3+)48。
    • 网络与权限
      • 确保节点间SSH无密码互通。
      • 防火墙开放YARN相关端口(如ResourceManager的8032、8088端口)4。
    • 依赖管理
      若将Spark JAR包上传至HDFS,需提前通过hadoop fs -put命令部署,避免任务运行时重复传输4。

    以上步骤通过整合Hadoop YARN与Spark配置实现集群资源统一管理,适用于生产环境的大规模任务调度。

相关推荐
数据库安全5 分钟前
首批|美创智能数据安全分类分级平台获CCIA“网络安全新产品”
大数据·人工智能·web安全
JiaJZhong34 分钟前
力扣.最长回文子串(c++)
java·c++·leetcode
Xy91044 分钟前
开发者视角:App Trace 一键拉起(Deep Linking)技术详解
java·前端·后端
一个混子程序员1 小时前
Mockito不常用的方法
java
敏叔V5871 小时前
SpringBoot实现MCP
java·spring boot·后端
小袁拒绝摆烂1 小时前
SpringCache整合SpringBoot使用
java·spring boot·后端
水果里面有苹果1 小时前
19-C#静态方法与静态类
java·开发语言·c#
袋鼠云数栈1 小时前
使用自然语言体验对话式MySQL数据库运维
大数据·运维·数据库·后端·mysql·ai·数据治理·数栈·data+ai
阿里云大数据AI技术1 小时前
数据 + 模型 驱动 AI Native 应用发展
大数据·数据库·人工智能
BUG批量生产者2 小时前
[746] 使用最小花费爬楼梯
java·开发语言