《零基础入门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 数量。

相关推荐
哆哆啦005 分钟前
使用 Obsidian + GitHub Actions + GitHub Pages 搭建内容发布流
数据库·笔记·github·obsidian
1892280486126 分钟前
NV243美光MT29F32T08GWLBHD6-24QJES:B
大数据·服务器·人工智能·科技·缓存
stars-he26 分钟前
基于 Python 的 DTMF 双音多频信号识别实验
学习·dsp开发
2601_9585484828 分钟前
利川避暑民宿舒适化运营:客流增长策略深度解析
大数据
明明跟你说过38 分钟前
Kafka 与 Elasticsearch 的集成应用案例深度解析
大数据·elk·elasticsearch·kafka·big data·bigdata
拾-光43 分钟前
【Git】命令大全:从入门到高手,100 个最常用命令速查(2026 版)
java·大数据·人工智能·git·python·elasticsearch·设计模式
2301_816997881 小时前
性能调优(基于 Elasticsearch 8.x)
大数据·elasticsearch·搜索引擎
wuxinyan1231 小时前
工业级大模型学习之路012:RAG 零基础入门教程(第七篇):高级检索架构(解决分块不合理问题)
人工智能·学习·rag
易知微EasyV数据可视化2 小时前
数序重构・智启新生|袋鼠云发布Data+AI智能飞轮战略,2026春季发布会圆满落幕
大数据·人工智能·经验分享·数字孪生·空间智能
xuhaoyu_cpp_java2 小时前
SpringMVC学习(五)
java·开发语言·经验分享·笔记·学习·spring