Hive特性--Hive1.x版本基于MR编程框架(Hive2.x之后是基于内存的,不再基于MR)

本文详细解析了Hive任务如何转换为MapReduce执行的过程,包括HQL语句的解析、元数据查询、抽象语法树的生成、逻辑与物理查询计划的制定,以及最终计划的执行和结果返回。

hive任务转换为mapreduce:
在这里插入图片描述

转换过程描述:

1、通过客户端或者UI界面执行HQL语句给Driver
2、Driver会为查询操作创建一个Session Handler,并将查询操作传递给Compiler去创建Execute Plan
3、Compiler根据任务去MetaStore查询hive元数据信息
4、Compiler得到元数据信息,对task进行编译,将HQL转换为抽象语法树,再将抽象语法树转换为查询块,
   再转换为逻辑查询plan,再转换为物理执行plan(mapreduce),最后选择最佳策略
5、将最佳的plan转交给Driver
6、Driver将plan转交给Execute Engine去执行,将获取到的hive元数据提交到ResouceManager去执行task
7、获取执行的结果并返回给Driver,然后UI/Cli去Driver中获取到结果
### Hive JAR包版本组成及意义 Hive JAR包的命名通常遵循以下格式:`hive-模块名-版本-cdhX.Y.Z.jar`。以`hive-common-2.3.6-cdh5.14.2.jar`为例,其具体含义如下: - **`hive-common`**:表示该JAR包属于Hive的公共模块,包含Hive的核心公共类工具[^1]。 - **`2.3.6`**:表示Hive的具体版本号,此处为2.3.6,属于Hive 2.x系列[^2]。 - **`cdh5.14.2`**:表示该版本由Cloudera发行,并基于Cloudera Distribution Hadoop (CDH) 5.14.2构建。CDH是Cloudera提供的Hadoop发行版,通常会对开源版本进行优化修复[^3]。 ### 在Zeppelin 0.10.0中的兼容性分析 Zeppelin 0.10.0支持与Hive 1.x到Hive 2.x版本的兼容性[^4]。因此,`hive-common-2.3.6-cdh5.14.2.jar`理论上可以在Zeppelin 0.10.0中使用,但需要注意以下几点: 1. **依赖一致性**:确保其他相关Hive模块(如`hive-exec`、`hive-metastore`)的版本与`hive-common-2.3.6-cdh5.14.2.jar`一致,否则可能导致类加载冲突或功能异常[^5]。 2. **CDH特定功能**:由于`hive-common-2.3.6-cdh5.14.2.jar`是基于CDH的定制版本,可能包含Cloudera特有的补丁或改动。如果Zeppelin运行环境未使用CDH,可能会出现兼容性问题。建议在相同或类似的Hadoop发行版环境中使用[^3]。 3. **配置调整**:在Zeppelin中使用自定义Hive JAR包时,需通过`ZEPPELIN_JAVA_OPTS`环境变量或直接将JAR包放置在Zeppelin的`lib`目录下。例如: ```bash export ZEPPELIN_JAVA_OPTS="-Dzeppelin.additional.jars=/path/to/hive-common-2.3.6-cdh5.14.2.jar" ``` 4. **执行引擎选择**:Hive 2.x版本默认使用MR作为执行引擎,但在Zeppelin中推荐考虑更高效的执行引擎(如Tez或Spark),以提高查询性能[^2]。 ### 示例代码 以下是一个简单的Zeppelin配置示例,展示如何加载自定义Hive JAR包并运行查询: ```python # 配置Zeppelin加载自定义Hive JAR包 export ZEPPELIN_JAVA_OPTS="-Dzeppelin.additional.jars=/path/to/hive-common-2.3.6-cdh5.14.2.jar" # 启动Zeppelin后,在Hive解释器中运行查询 %hive SHOW DATABASES; ``` ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值