《零基础入门Spark》学习笔记 Day 10

Hive与Spark联合

Hive与Spark组合中,Hive擅长元数据管理,Spark专长是高效的分布式计算,两者集成方式有两种:从Spark角度出发,Spark with Hive,从Hive出发即是Hive on Spark。

HIve架构与基本原理

Hive的核心部件主要是User Interface和Drvier。不论是元数据库、存储系统,还是计算引擎,Hive都是以"外包"、"可插拨"的方式交给第三方独立组件。

Hive查询执行流程

  1. 提交查询

    用户通过 CLI、JDBC 或 Web UI 提交 HiveQL 查询(如 SELECT * FROM table WHERE condition)。

  2. 解析与编译

    Driver 组件解析查询,检查语法和语义,访问 Metastore 获取元数据,生成 DAG 形式的执行计划。

  3. 优化与执行

    优化器应用规则优化执行计划(如列剪裁、分区过滤),执行引擎将计划转换为 MapReduce/Tez/Spark 任务。

  4. 结果返回

    计算结果写入临时文件或直接返回客户端,对于大规模结果通常存储到 HDFS 表。

Metastore的重要作用之一,是帮助底层计算引擎高效地定位并访问分布式文件系统中的数据源。Hive支持3类计算引擎,分别是Hadoop MapReduce、Tez和Spark。

Spark with Hive

可以通过3种途径来实现Spark with Hive

1、创建SparkSession,访问本地或远程的Hive Metastore;

2、通过Spark内置的spark-sql CLI,访问本地Hive Metastore;

3、通过Beeline客户羰,访问Spark Thrift Server.

不论是SparkSession+Hive Metastore、Spark-sql CLI+Hive Metastore,还是Beeline+Spark Thrift Server,Spark扮演的角色都是执行引擎,而Hive的作用主要在于通过Metastore提供底层数据集的元数据。

Hive on Spark

在Hive on Spark这种集成模式下,Hive与Spark衔接的部分是Spark Core,而不是Spark SQL,这一点需要我们特别注意

1、查询解析与编译

Hive 接收到 HQL 查询后,通过解析器(Parser)将 SQL 转换为抽象语法树(AST)。

语法树经过语义分析(Semantic Analyzer)验证表、列是否存在,并生成逻辑执行计划(Logical Plan)。

逻辑计划通过优化器(Optimizer)进行规则优化(如谓词下推、列裁剪等),生成优化后的逻辑计划。

2、物理计划生成

优化后的逻辑计划被转换为物理执行计划(Physical Plan),此时任务会被拆分为多个 MapReduce 或 Spark 阶段(Stage)。

在 Hive on Spark 中,物理计划会被转换为 Spark 的 DAG(有向无环图),每个节点对应 Spark 的 RDD 操作(如 mapreduceByKey)。

3、Spark 任务提交

Hive 通过 SparkClient 将生成的 DAG 提交到 Spark 集群。

Spark Driver 接收到任务后,将 DAG 划分为多个 Stage,每个 Stage 包含多个 Task。

Task 由 Spark Executor 在集群节点上执行,期间涉及数据的分区、Shuffle 和聚合操作。

4、数据读取与计算

数据从 HDFS 或 Hive 表存储(如 ORC、Parquet)通过 Spark 的 HadoopRDD 加载到内存。

Spark 执行转换操作(如 filterjoin),触发 Shuffle 时通过 ShuffleManager(如 SortShuffleManager)管理数据分发。

最终结果通过 Collect 或写入表的方式返回给 Hive。

5、资源管理与调度

资源由 Spark 的集群管理器(如 YARN、Mesos 或 Spark Standalone)分配。

Hive 通过 SparkSession 管理 Spark 上下文,确保任务隔离和资源复用。

动态资源分配(Dynamic Allocation)可根据负载调整 Executor 数量。

相关推荐
源码之家2 小时前
计算机毕业设计:汽车数据可视化分析系统 Django框架 Scrapy爬虫 可视化 数据分析 大数据 大模型 机器学习(建议收藏)✅
大数据·python·信息可视化·flask·汽车·课程设计·美食
AI视觉网奇2 小时前
fp8 量化笔记
人工智能·笔记
二进制_博客2 小时前
Spark On Hive 系统整合
大数据·hive·spark
D愿你归来仍是少年2 小时前
Apache Flink 学习笔记 · Phase 1
大数据·flink·apache
白眼黑刺猬2 小时前
真实面试:大数据开发岗
大数据·面试·职场和发展
D愿你归来仍是少年2 小时前
Apache Spark 第 13 章:Real-Time Mode 实时计算
大数据·spark·apache
源码之家2 小时前
计算机毕业设计:基于Python的二手车数据分析可视化系统 Flask框架 可视化 时间序列预测算法 逻辑回归 requests 爬虫 大数据(建议收藏)✅
大数据·hadoop·python·算法·数据分析·flask·课程设计
昨夜见军贴06162 小时前
AI报告文档审核赋能数据不出域:IACheck重构机械制造行业本地化质量管控体系
大数据·人工智能·重构
red_redemption2 小时前
自由学习记录(152)
学习