【spark3.2.4】--完全分布式集群搭建

一、spark-env.sh 文件配置(操作路径:$SPARK_HOME/conf/spark-env.sh

如果还没创建:

bash 复制代码
cp $SPARK_HOME/conf/spark-env.sh.template $SPARK_HOME/conf/spark-env.sh

然后编辑(比如用 vim):

bash 复制代码
vim $SPARK_HOME/conf/spark-env.sh

修改内容如下:

bash 复制代码
# Java 环境
export JAVA_HOME=/usr/local/src/jdk1.8.0_152

# Hadoop 配置目录(用于对接 HDFS)
export HADOOP_CONF_DIR=/usr/local/src/hadoop-3.2.2/etc/hadoop

# Spark Master 配置
export SPARK_MASTER_HOST=master01
export SPARK_MASTER_PORT=7077

# Spark Worker 资源限制
export SPARK_WORKER_MEMORY=1g
export SPARK_WORKER_CORES=2
export SPARK_WORKER_INSTANCES=1

# History Server 配置(写入 event log)
export SPARK_HISTORY_OPTS="-Dspark.history.fs.logDirectory=hdfs://master01:8020/spark-logs -Dspark.history.fs.cleaner.enabled=true -Dspark.history.fs.cleaner.maxAge=7d"

二、workers 文件配置(操作路径:$SPARK_HOME/conf/workers

如果还没创建:

bash 复制代码
cp $SPARK_HOME/conf/workers.template $SPARK_HOME/conf/workers

编辑文件:

bash 复制代码
vim $SPARK_HOME/conf/workers

写入每台 Worker 的 hostname(或 IP):

bash 复制代码
node01
node02

可选写法(如果 DNS 不通):

bash 复制代码
192.168.1.102
192.168.1.103

三、spark-defaults.conf 文件配置(操作路径:$SPARK_HOME/conf/spark-defaults.conf

如果还没创建:

bash 复制代码
cp $SPARK_HOME/conf/spark-defaults.conf.template $SPARK_HOME/conf/spark-defaults.conf

编辑文件:

bash 复制代码
vim $SPARK_HOME/conf/spark-defaults.conf

推荐配置内容如下:

properties 复制代码
# 集群主节点
spark.master                     spark://master01:7077

# 提交模式(client 适合测试,部署集群可用 cluster)
spark.submit.deployMode          client

# 启用事件日志
spark.eventLog.enabled           true
spark.eventLog.dir               hdfs://master01:8020/spark-logs

# 历史服务器读取的日志目录
spark.history.fs.logDirectory    hdfs://master01:8020/spark-logs

# 日志自动清理设置
spark.history.fs.cleaner.enabled true
spark.history.fs.cleaner.maxAge  7d

# 默认 executor 资源设置
spark.executor.memory            1g
spark.executor.cores             1

# driver 内存设置(本地运行任务时用)
spark.driver.memory              1g

四、HDFS 中创建日志目录

bash 复制代码
hdfs dfs -mkdir -p /spark-logs
hdfs dfs -chmod -R 755 /spark-logs

如果你用的是非 root 用户运行 Spark,比如 sparkuser

bash 复制代码
hdfs dfs -chown sparkuser:hadoop /spark-logs

五、启动服务推荐顺序

bash 复制代码
# 启动 Hadoop 集群
start-dfs.sh

# 启动 Spark 集群
start-all.sh

# 启动 Spark 历史服务器
start-history-server.sh

# 查看 UI 页面(History Server 默认 18080)
http://master01:18080
相关推荐
^辞安16 小时前
RocketMQ为什么自研Nameserver而不用zookeeper?
分布式·zookeeper·rocketmq
在未来等你18 小时前
Kafka面试精讲 Day 8:日志清理与数据保留策略
大数据·分布式·面试·kafka·消息队列
poemyang19 小时前
“你还活着吗?” “我没死,只是网卡了!”——来自分布式世界的“生死契约”
分布式
echoyu.19 小时前
消息队列-初识kafka
java·分布式·后端·spring cloud·中间件·架构·kafka
明达智控技术20 小时前
MR30分布式I/O在面机装备中的应用
分布式·物联网·自动化
JAVA学习通1 天前
【RabbitMQ】---RabbitMQ 工作流程和 web 界面介绍
分布式·rabbitmq
安卓开发者1 天前
鸿蒙NEXT应用数据持久化全面解析:从用户首选项到分布式数据库
数据库·分布式·harmonyos
JAVA学习通1 天前
【RabbitMQ】如何在 Ubuntu 安装 RabbitMQ
分布式·rabbitmq
Lansonli1 天前
大数据Spark(六十三):RDD-Resilient Distributed Dataset
大数据·分布式·spark
BYSJMG1 天前
计算机毕业设计选题:基于Spark+Hadoop的健康饮食营养数据分析系统【源码+文档+调试】
大数据·vue.js·hadoop·分布式·spark·django·课程设计