HIVE SQL 底层执行逻辑

56 篇文章 11 订阅
55 篇文章 1 订阅

HIVE SQL 底层执行逻辑

hive可以通过访问HDFS等,通过MR引擎(或者更换的Spark、Tez等)执行查询逻辑,一个hive sql会被解译为若干个mr流程,那么是怎么执行的?

一、HIVE五大组件

在hive中,有很重要的五个组件

  1. UI

    用户界面,也就是hive提供给用户的可视化工具

  2. DRIVER

    驱动程序,十分关键的一部分

  3. COMPLIER

    编译器。负责将HIVE SQL翻译成可执行的执行计划

  4. METASTORE

    元数据库。存储各种表和分区所有的结构信息

  5. EXECUTION ENGIGN

    执行引擎。将解译好的执行计划提交到不同的引擎上。MR、Spark、Tez

二、执行过程

执行过程可以简单的理解为

  1. 通过UI提交代码
  2. 编译器编译,生成执行计划
  3. 获取执行计划中需要的元数据
  4. 为执行计划划分阶段
  5. 执行任务
  6. 任务结束,返回到UI

步骤1:UI调用DRIVER的接口

步骤2:DRIVER为查询创建会话句柄,并将查询发送到编译器生成执行计划

步骤3:编译器从元数据存储中获取输入输出元数据

步骤4:编译器生成的计划是分阶段的DAG,每个阶段要么是map任务,要么是reduce任务,从而将生成的计划发给DRIVER

步骤5:执行引擎将任务提交到对应的引擎。在每个 task(mapper/reducer) 中,从HDFS文件中读取与表或中间输出相关联的数据,并通过相关算子树传递这些数据。最终这些数据通过序列化器写入到一个临时HDFS文件中(如果不需要 reduce 阶段,则在 map 中操作)。临时文件用于向计划中后面的 map/reduce 阶段提供数据。

步骤6:最终的临时文件移动到表的位置
在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Hive SQL执行流程可以分为三个主要步骤。首先,Hive 会将用户编写的 SQL 语句进行词法分析和语法分析,生成一个抽象语法树(AST)表示用户查询的结构。这个过程叫做查询解析。在这个过程中,HiveSQL 语句转化为一个 QueryBlock 对象,用来表示查询的结构和语义。 接下来,Hive 会对 QueryBlock 进行语义分析,检查查询中的表、列、函数等是否存在以及其它语义上的错误。在这个步骤中,Hive 还会进行表的访问控制和权限检查。一旦通过了语义分析,Hive 就会生成一个逻辑查询计划(Logical Plan)。逻辑查询计划描述了查询的逻辑操作,例如选择、投影和连接等。 最后,Hive 会将逻辑查询计划转化为物理查询计划(Physical Plan),并生成对应的 MapReduce 程序。这个过程叫做查询优化和执行计划生成。在这个步骤中,Hive 会进行各种优化,例如谓词下推、列裁剪和任务并行化等,以提高查询的性能。最终,Hive 会将生成的 MapReduce 程序提交给底层的计算引擎进行执行,计算结果将返回给用户。 综上所述,Hive SQL执行流程包括查询解析、语义分析和查询优化及执行计划生成三个主要步骤。通过这些步骤,Hive 能够将用户编写的 SQL 转化为 MapReduce 等计算引擎可识别的程序,并实现查询的执行。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Hive SQL底层编译过程详解](https://blog.csdn.net/helloHbulie/article/details/117283369)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牧码文

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值