如何搭建spark yarn模式的集群

1. 环境准备

  • 节点规划 :假设有三个节点,分别为 masterslave1slave2master 节点同时作为 Hadoop 的 NameNode 和 ResourceManager,slave1slave2 作为 DataNode 和 NodeManager。

  • 安装 JDK :确保所有节点都安装了 Java 8 或更高版本,并且配置好 JAVA_HOME 环境变量。

    示例:设置 JAVA_HOME

    export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64
    export PATH=PATH:JAVA_HOME/bin

  • 配置 SSH 免密登录 :在 master 节点上生成 SSH 密钥,并将公钥分发到所有节点,包括 master 自身。

    在 master 节点生成密钥

    ssh-keygen -t rsa

    将公钥复制到所有节点

    ssh-copy-id master
    ssh-copy-id slave1
    ssh-copy-id slave2

2. 安装和配置 Hadoop

2.1 下载和解压 Hadoop

从 Apache 官网下载 Hadoop 3.x 版本,并解压到指定目录。

复制代码
wget https://downloads.apache.org/hadoop/common/hadoop-3.3.4/hadoop-3.3.4.tar.gz
tar -zxvf hadoop-3.3.4.tar.gz -C /usr/local
cd /usr/local
ln -s hadoop-3.3.4 hadoop
2.2 配置 Hadoop 环境变量

/etc/profile~/.bashrc 中添加以下内容:

复制代码
export HADOOP_HOME=/usr/local/hadoop
export PATH=$PATH:$HADOOP_HOME/bin:$HADOOP_HOME/sbin

使配置生效:

复制代码
source /etc/profile
2.3 配置 Hadoop 核心文件
  • core-site.xml

    <configuration> <property> <name>fs.defaultFS</name> <value>hdfs://master:9000</value> </property> <property> <name>hadoop.tmp.dir</name> <value>/usr/local/hadoop/tmp</value> </property> </configuration>
  • hdfs-site.xml

xml

复制代码
<configuration>
    <property>
        <name>dfs.replication</name>
        <value>2</value>
    </property>
    <property>
        <name>dfs.namenode.name.dir</name>
        <value>/usr/local/hadoop/hdfs/namenode</value>
    </property>
    <property>
        <name>dfs.datanode.data.dir</name>
        <value>/usr/local/hadoop/hdfs/datanode</value>
    </property>
</configuration>
  • mapred-site.xml

xml

复制代码
<configuration>
    <property>
        <name>mapreduce.framework.name</name>
        <value>yarn</value>
    </property>
</configuration>
  • yarn-site.xml

xml

复制代码
<configuration>
    <property>
        <name>yarn.resourcemanager.hostname</name>
        <value>master</value>
    </property>
    <property>
        <name>yarn.nodemanager.aux-services</name>
        <value>mapreduce_shuffle</value>
    </property>
</configuration>
2.4 配置从节点

$HADOOP_HOME/etc/hadoop/slaves 文件中添加从节点的主机名:

plaintext

复制代码
slave1
slave2
2.5 格式化 NameNode

master 节点上执行以下命令:

bash

复制代码
hdfs namenode -format
2.6 启动 Hadoop 集群

master 节点上启动 HDFS 和 YARN:

bash

复制代码
start-dfs.sh
start-yarn.sh

3. 安装和配置 Spark

3.1 下载和解压 Spark

从 Apache 官网下载 Spark 3.x 版本,并解压到指定目录。

bash

复制代码
wget https://downloads.apache.org/spark/spark-3.3.2/spark-3.3.2-bin-hadoop3.tgz
tar -zxvf spark-3.3.2-bin-hadoop3.tgz -C /usr/local
cd /usr/local
ln -s spark-3.3.2-bin-hadoop3 spark
3.2 配置 Spark 环境变量

/etc/profile~/.bashrc 中添加以下内容:

bash

复制代码
export SPARK_HOME=/usr/local/spark
export PATH=$PATH:$SPARK_HOME/bin:$SPARK_HOME/sbin

使配置生效:

bash

复制代码
source /etc/profile
3.3 配置 Spark 核心文件

bash

复制代码
export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64
export HADOOP_CONF_DIR=/usr/local/hadoop/etc/hadoop
export SPARK_EXECUTOR_CORES=2
export SPARK_EXECUTOR_MEMORY=2G
export SPARK_DRIVER_MEMORY=1G
  • spark-defaults.conf

plaintext

复制代码
spark.master yarn
spark.submit.deployMode cluster
3.4 分发 Spark 到所有节点

将 Spark 目录复制到所有节点:

bash

复制代码
scp -r /usr/local/spark slave1:/usr/local
scp -r /usr/local/spark slave2:/usr/local

4. 验证集群

master 节点上运行一个简单的 Spark 应用程序:

bash

复制代码
spark-submit --class org.apache.spark.examples.SparkPi \
    --master yarn \
    --deploy-mode cluster \
    $SPARK_HOME/examples/jars/spark-examples_2.12-3.3.2.jar 10

如果应用程序成功运行并输出结果,则说明 Spark YARN 模式集群搭建成功。

5. 常见问题及解决方法

  • 网络问题:确保所有节点之间可以相互 ping 通,并且防火墙已开放必要的端口。
  • 权限问题:确保所有节点上的 Hadoop 和 Spark 目录具有正确的权限。
  • 配置问题 :检查所有配置文件是否正确,特别是 core-site.xmlhdfs-site.xmlyarn-site.xmlspark-env.sh
相关推荐
Lalolander43 分钟前
设备制造行业项目管理难点解析,如何有效解决?
大数据·制造·工程项目管理·四算一控·epc·装备制造项目管理
项目管理打工人43 分钟前
高端装备制造企业如何选择适配的项目管理系统提升项目执行效率?附选型案例
大数据·人工智能·驱动开发·科技·硬件工程·团队开发·制造
shangjg32 小时前
Kafka 如何保证不重复消费
java·分布式·后端·kafka
A尘埃2 小时前
Kafka消息中间件
分布式·kafka
武子康3 小时前
大数据-274 Spark MLib - 基础介绍 机器学习算法 剪枝 后剪枝 ID3 C4.5 CART
大数据·人工智能·算法·机器学习·语言模型·spark-ml·剪枝
小马过河R5 小时前
不加载PHP OpenTelemetry SDK实现Trace‌与Logs
开发语言·分布式·微服务·云原生·php
加百力6 小时前
戴尔AI服务器订单激增至121亿美元,但传统业务承压
大数据·服务器·人工智能
计算机毕设定制辅导-无忧学长7 小时前
RabbitMQ 源码剖析:消息存储与协议实现(一)
分布式·rabbitmq
会敲键盘的猕猴桃很大胆7 小时前
Redis实战-基于redis和lua脚本实现分布式锁以及Redission源码解析【万字长文】
java·redis·分布式·spring·lua
TGITCIC9 小时前
数据基座觉醒!大数据+AI如何重构企业智能决策金字塔(下)
大数据·大数据ai·大模型落地·大模型大数据·ai与大数据结合·大数据集成ai·企业ai