当前位置: 首页 > news >正文

Spark 从入门到部署:核心模块解析与 Yarn 模式实战指南

Spark 从入门到部署:核心模块解析与 Yarn 模式实战指南

文章目录

  • Spark 从入门到部署:核心模块解析与 Yarn 模式实战指南
    • 一、Spark核心模块
    • 二、安装模式
      • 1、本地模式
      • 2、Standalone模式
      • 3、Yarn模式
      • 视频部署教程

一、Spark核心模块

摘要:本文系统介绍了Apache Spark大数据计算引擎的核心模块(Spark Core、Spark SQL、Spark Streaming、Spark MLlib、Spark GraphX)及其功能,并详细讲解了Spark的三种安装模式:本地模式、Standalone模式和Yarn模式。重点以Yarn模式为例,演示了从解压缩、配置文件修改、Hadoop集群启动到应用提交的完整部署流程,并配置了历史服务器以记录任务运行情况。

Spark是一种基于内存的快速、通用、可扩展的大数据分析计算引擎。

Spark是一种由Scala语言开发的快速、通用、可扩展的大数据分析引擎
➢ Spark Core
Spark Core中提供了Spark最基础与最核心的功能,Spark其他的功能如:Spark SQL,Spark Streaming,GraphX, MLlib都是在Spark Core的基础上进行扩展的
➢ Spark SQL
Spark SQL是Spark用来操作结构化数据的组件。通过Spark SQL,用户可以使用SQL或者Apache Hive版本的SQL方言(HQL)来查询数据。
➢ Spark Streaming
Spark Streaming是Spark平台上针对实时数据进行流式计算的组件,提供了丰富的处理数据流的API。
➢ Spark MLlib
MLlib是Spark提供的一个机器学习算法库。MLlib不仅提供了模型评估、数据导入等额外的功能,还提供了一些更底层的机器学习原语。
➢ Spark GraphX
GraphX是Spark面向图计算提供的框架与算法库。

二、安装模式

1、本地模式

基本测试,单机

2、Standalone模式

只使用Spark自身节点运行的集群模式,也就是我们所谓的独立部署(Standalone)模式。
spark本身自带了完整的资源调度管理服务,可以独立部署到一个集群中,无须依赖任何其他的资源管理系统。该模式下,同样为主从模式,即一台Master与多台Slave节点。

3、Yarn模式

Yarn模式被称为Spark on Yarn模式,即把Spark作为一个客户端,将作业提交给Yarn服务,由于在生产环境中,很多时候都要与Hadoop使用同一个集群,因此采用Yarn来管理资源调度,可以有效提高资源利用率。
独立部署(Standalone)模式由Spark自身提供计算资源,无需其他框架提供资源。这种方式降低了和其他第三方资源框架的耦合性,独立性非常强。但是也要记住,Spark主要是计算框架,而不是资源调度框架,所以本身提供的资源调度并不是它的强项,所以还是和其他专业的资源调度框架集成会更靠谱一些。
2.3.1 解压缩文件
将spark-2.3.2-bin-hadoop2.7.tgz文件上传到linux并解压缩,放置在指定位置。

[root@master ~]$cd/opt/software[root@master software]$tar-zvxfspark-2.3.2-bin-hadoop2.7.tgz-C/opt/module[root@master software]$cd/opt/module[root@master module]$mvspark-2.3.2-bin-hadoop2.7/ spark

2.3.2 修改配置文件

  1. 修改hadoop配置文件/opt/module/hadoop/etc/hadoop/yarn-site.xml, 并分发。
<!--是否启动一个线程检查每个任务正使用的物理内存量,如果任务超出分配值,则直接将其杀掉,默认是true --><property><name>yarn.nodemanager.pmem-check-enabled</name><value>false</value></property><!--是否启动一个线程检查每个任务正使用的虚拟内存量,如果任务超出分配值,则直接将其杀掉,默认是true --><property><name>yarn.nodemanager.vmem-check-enabled</name><value>false</value></property>
  1. 修改/opt/module/spark/conf/spark-env.sh,添加JAVA_HOME、YARN_CONF_DIR和HADOOP_CONF_DIR配置
exportJAVA_HOME=/opt/module/javaexportYARN_CONF_DIR=/opt/module/hadoop/etc/hadoopexportHADOOP_CONF_DIR=/opt/module/hadoop/etc/hadoop

2.3.3 启动Hadoop集群
2.3.4 提交应用

[root@master spark]$ bin/spark-submit\-- class org.apache.spark.examples.SparkPi\-- masteryarn\-- deploy-modecluster\./examples/jars/spark-examples_2.12-3.0.0.jar\10

查看master:8088页面,点击History,查看历史页面

2.3.5 配置历史服务器
由于spark-shell停止掉后

历史服务器的配置与工作流程如下:

Spark 作业运行

写入事件日志

HDFS 日志存储目录
hdfs://master:8020/directory

History Server
端口 18080

Web UI 展示
master:8088

查看历史任务
运行详情

,集群监控master:4040页面就看不到历史任务的运行情况,所以开发时都配置历史服务器记录任务运行情况。

  1. 复制spark-defaults.conf.template文件为spark-defaults.conf
cpspark-defaults.conf.template spark-defaults.conf
  1. 修改 spark-default.conf文件,配置日志存储路径
spark.eventLog.enabledtruespark.eventLog.dir hdfs://master:8020/directory

注意:需要启动hadoop集群,HDFS上的目录需要提前存在。

[root@master conf]$ hdfs dfs-mkdir/directory
  1. 修改 spark-env.sh文件 , 添加日志配置
exportSPARK_HISTORY_OPTS=" -Dspark.history.ui.port=18080 -Dspark.history.fs.logDirectory=hdfs://master:8020/directory -Dspark.history.retainedApplications=30"

⚫ 参数1含义:WEB UI访问的端口号为18080
⚫ 参数2含义:指定历史服务器日志存储路径
⚫ 参数3含义:指定保存Application历史记录的个数,如果超过这个值,旧的应用程序信息将被删除,这个是内存中的应用数,而不是页面上显示的应用数。
4) 修改spark-defaults.conf

spark.yarn.historyServer.address=master:18080spark.history.ui.port=18080

5)启动历史服务

sbin/start-history-server.sh

6)重新提交应用

sbin/start-history-server.sh bin/spark-submit\-- class org.apache.spark.examples.SparkPi\-- masteryarn\-- deploy-mode client -- ./examples/jars/spark-examples_2.12-3.0.0.jar\10


7)web页面查看日志:master:8088

视频部署教程

https://www.bilibili.com/video/BV1TXLt6vEbr/?spm_id_from=333.1387.collection.video_card.click&vd_source=1a334fb1947370a7879f0821dabcbf29

http://www.jsqmd.com/news/861380/

相关文章:

  • BOSCH SM50/100-T伺服驱动器
  • 《数据主权时代,企业协作需切换“私有模式”》
  • 【优化 v 2.7.5 版本】PC 端 Open Claw 一键部署详细教学
  • 家居建材营销新趋势:数字化、体验式与可持续方向-佛山鼎策创局破局增长咨询有限公司
  • ⾯向对象和集合编程题
  • 在鸿蒙上跑一个端侧大模型——不用连云端数据全在本地
  • Java Comparator深度解析:从底层原理到实战应用
  • 内存管理与垃圾回收原理及机器学习实验研究
  • 一篇文章讲清楚—Windows 电脑中 CMD 和 PowerShell 有啥区别
  • 从CRUD到AI大神:小白程序员5个月逆袭之路(收藏版)
  • WorkBuddy:一个面向内容创作的桌面自动化助手实践
  • 1794-ACN15适配器模块
  • ComfyUI v0.22.0 更新:工作流模板升级、音频与多模态增强、OpenAPI 文档完善、节点能力大幅扩展
  • 2026年4月制冷厂推荐:制冷机组、制冷设备品牌、南宁制冷、反应釜制冷设备、商丘制冷、太原制冷、安徽冷水机、安徽制冷选择指南 - 优质品牌商家
  • Agent 认知破局:从具象表象到交互本质
  • EPRO MMS6120振动检测模块
  • 2026丛林穿越厂家怎么选:户外丛林穿越厂家、无动力乐园规划设计、无动力游乐设备非标定制、游乐场无动力游乐设备选择指南 - 优质品牌商家
  • 抖音获客失效?拆解本地商家流量困局的底层逻辑与破局路径
  • Linux 硬盘分区管理
  • 高性价比塑料链板输送机厂家排行适配指南
  • c语言中语句分类
  • Chiplet经济学:成本如何影响芯片产业发展?
  • 护照阅读器在海外的经典案例分享
  • fastapi · FastAPI framework, high performance, easy to learn, fast to code, ready for production
  • 鸿蒙PC的包管理工具 Homebrew 正式上线,Harmonybrew介绍及使用指南
  • 1987年5月15日中午11-13点出生性格、运势和命运
  • 从零开始学AI Agent:软件工程视角下的企业数字化转型实践指南(收藏版)
  • HBase 分布式集群部署实战:从解压到启动的完整指南
  • 健身 Agent:不止视频,更有 AI 人物实时跟练交互
  • 分享高三模拟卷资源盘点