如何搭建spark yarn 模式的集群集群。

以下是的 Spark YARN 模式集群搭建步骤:

一、环境准备

  1. 服务器规划
  • 至少 3 台节点:1 台主节点(运行 HDFS NameNode、YARN ResourceManager),2 台从节点(运行 HDFS DataNode、YARN NodeManager)。

  • 软件要求:JDK 1.8+、Hadoop 3.x(含 HDFS 和 YARN)、Spark 3.x。

  1. 基础配置
  • 关闭防火墙和 SELinux:

bash

systemctl stop firewalld && systemctl disable firewalld

sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config

  • 配置主节点到从节点的 SSH 免密登录。

  • 同步系统时间(如使用 ntpdate )。

二、安装与配置 Hadoop(YARN 依赖)

  1. 解压安装

bash

tar -zxvf hadoop-3.x.tar.gz -C /opt/

mv /opt/hadoop-3.x /opt/hadoop

  1. 配置环境变量

在 ~/.bashrc 中添加:

bash

export HADOOP_HOME=/opt/hadoop

export PATH=PATH:HADOOP_HOME/bin:$HADOOP_HOME/sbin

执行 source ~/.bashrc 生效。

  1. 修改核心配置文件
  • hadoop-env.sh :指定 JDK 路径(如 export JAVA_HOME=/usr/java/jdk1.8.0_301 )。

  • core-site.xml :

xml

<property>

<name>fs.defaultFS</name>

<value>hdfs://主节点IP:9000</value>

</property>

  • hdfs-site.xml :

xml

<property>

<name>dfs.replication</name>

<value>2</value> <!-- 数据副本数,根据节点数调整 -->

</property>

  • yarn-site.xml :

xml

<property>

<name>yarn.resourcemanager.hostname</name>

<value>主节点IP</value>

</property>

  1. 启动 Hadoop

bash

hdfs namenode -format # 首次初始化 namenode

start-dfs.sh # 启动 HDFS

start-yarn.sh # 启动 YARN

三、安装与配置 Spark

  1. 解压安装

bash

tar -zxvf spark-3.x-bin-hadoop3.x.tgz -C /opt/

mv /opt/spark-3.x-bin-hadoop3.x /opt/spark

  1. 配置环境变量

在 ~/.bashrc 中添加:

bash

export SPARK_HOME=/opt/spark

export PATH=PATH:SPARK_HOME/bin:$SPARK_HOME/sbin

执行 source ~/.bashrc 生效。

  1. 修改 Spark 配置

bash

cp /opt/spark/conf/spark-env.sh.template /opt/spark/conf/spark-env.sh

echo "export HADOOP_CONF_DIR=/opt/hadoop/etc/hadoop" >> /opt/spark/conf/spark-env.sh

echo "export SPARK_MASTER_IP=主节点IP" >> /opt/spark/conf/spark-env.sh

  • 编辑 slaves 文件(无后缀),添加从节点 IP(每行一个,如 从节点1IP 从节点2IP )。
  1. 分发到从节点

bash

scp -r /opt/spark 从节点1IP:/opt/

scp -r /opt/spark 从节点2IP:/opt/

从节点执行 source ~/.bashrc 生效。

四、启动 Spark 集群(YARN 模式)

Spark on YARN 无需单独启动 Spark 集群,直接提交任务到 YARN 即可:

  1. 提交任务示例

bash

spark-submit \

--master yarn \

--deploy-mode cluster \ # 集群模式(AM 运行在 YARN 中)

--executor-memory 2g \

--num-executors 2 \

/opt/spark/examples/jars/spark-examples_*.jar wordcount \

hdfs:///input.txt hdfs:///output

  1. 验证
  • 通过 YARN 界面(默认端口 8088 )查看任务运行状态。

  • 通过 Spark 历史服务器(配置 spark.history.fs.logDirectory 并启动 start-history-server.sh )查看任务日志。

关键说明

  • YARN 模式特点:Spark 任务直接运行在 YARN 资源管理器上,无需维护独立的 Spark 集群。

  • 配置调优:根据服务器资源调整 yarn.nodemanager.resource.memory-mb (YARN 内存)和 Spark 任务参数(如 --executor-memory )。

相关推荐
极光代码工作室14 天前
基于数据仓库的电商数据分析平台
大数据·hadoop·python·spark·数据可视化
JLWcai2025100914 天前
铸造领域树脂砂轮|金利威多场景解决方案,20 + 配方覆盖全需求
mongodb·zookeeper·eureka·spark·rabbitmq·memcached·storm
ACP广源盛1392462567314 天前
GSV9001S@ACP#1080P 级视频处理芯片,物理 AI 普及终端的高性价比选择
大数据·人工智能·分布式·嵌入式硬件·spark
木心术114 天前
AMD Ryzen AI Halo与NVIDIA RTX Spark/DGX Spark两款AI个人主机的差异和优劣势
大数据·人工智能·spark
ACP广源盛1392462567315 天前
GSV5600@ACP#多接口协议转换芯片,物理 AI 便携终端的互联核心
大数据·人工智能·分布式·嵌入式硬件·spark
KaMeidebaby15 天前
卡梅德生物技术快报 | 噬菌体展示 12 肽文库在蛋白表位定位中的应用与实验数据
大数据·人工智能·架构·spark·新浪微博
ACP广源盛1392462567316 天前
GSV2221@ACP#DP 1.4 MST 多屏转换芯片,物理 AI 多模态交互的视觉中枢
大数据·人工智能·嵌入式硬件·gpt·spark
想ai抽16 天前
Spark Executor 因节点内存超限被杀的分析与应对
大数据·性能优化·spark
simidagogogo16 天前
生产环境推荐系统最隐蔽的坑:Training-Serving Skew 详解与实战
算法·spark·推荐算法
ACP广源盛1392462567316 天前
GSV6155@ACP#DP 1.4a 重定时器芯片,物理 AI 信号长距传输的稳定保障
大数据·人工智能·分布式·嵌入式硬件·spark