Hive数据倾斜解决方案

本文介绍了解决Hive中数据倾斜的方法,包括参数调节如启用Map端部分聚合和负载均衡,及SQL语句调节策略如合理选择驱动表、使用mapjoin、处理空值key等。

数据倾斜的解决方案

2.1参数调节: hive.map.aggr=true

Map 端部分聚合,相当于Combiner

hive.groupby.skewindata=true

有数据倾斜的时候进行负载均衡,当选项设定为 true,生成的查询计划会有两个 MR Job。第一个 MR Job 中,Map
的输出结果集合会随机分布到 Reduce 中,每个 Reduce 做部分聚合操作,并输出结果,这样处理的结果是相同的 Group By
Key 有可能被分发到不同的 Reduce 中,从而达到负载均衡的目的;第二个 MR Job 再根据预处理的数据结果按照 Group By
Key 分布到 Reduce 中(这个过程可以保证相同的 Group By Key 被分布到同一个 Reduce
中),最后完成最终的聚合操作。

2.2 SQL语句调节: 如何Join:

关于驱动表的选取,选用join key分布最均匀的表作为驱动表

做好列裁剪和filter操作,以达到两表做join的时候,数据量相对变小的效果。

大小表Join:

使用map join让小的维度表(1000条以下的记录条数) 先进内存。在map端完成reduce.

大表Join大表:

把空值的key变成一个字符串加上随机数,把倾斜的数据分到不同的reduce上,由于null值关联不上,处理后并不影响最终结果。

count distinct大量相同特殊值

count distinct时,将值为空的情况单独处理,如果是计算count
distinct,可以不用处理,直接过滤,在最后结果中加1。如果还有其他计算,需要进行group
by,可以先将值为空的记录单独处理,再和其他计算结果进行union。

group by维度过小:

采用sum() group by的方式来替换count(distinct)完成计算。

Hive 数据倾斜是指在数据处理过程中,某些任务处理的数据量远远超过其他任务,导致整体任务执行效率低下。以下是一些解决 Hive 数据倾斜的办法: ### Hive ETL 预处理数据 如果导致数据倾斜的表是 Hive 表,且数据分布不均匀,而业务需要频繁对该表执行某个分析操作,可以尝试使用 Hive ETL 预处理数据,按 key 进行聚合,或预先和其他表 join。之后所有操作针对的数据源就不是原来的 Hive 表,而是预处理之后的 Hive 表。不过要注意,因为数据本身存在分布不均匀的问题,所以在 Hive ETL 过程中还是会存在数据倾斜,导致 Hive ETL 速度很慢,只是把数据倾斜的发生提前到了 Hive ETL 中。此方案执行起来简单便捷,效果较好 [^1]。 ### 增加并行度 增加并行度可以让任务分配到更多的计算资源上,从而缓解数据倾斜的问题。可以通过调整 `mapred.reduce.tasks` 参数来增加 reduce 任务的数量,示例代码如下: ```sql SET mapred.reduce.tasks = 100; ``` ### 开启自动优化倾斜的 JOIN 通过 `hive.optimize.skewjoin` 参数用于处理在执行 JOIN 操作时可能出现的数据倾斜问题,默认为 false。设置这个参数为 true 可以让 Hive 自动优化和处理倾斜的 JOIN,从而提高查询性能 [^2]。 ```sql SET hive.optimize.skewjoin = true; ``` ### 避免 Count Distinct 问题 目前 Reduce 端数据倾斜很多是由 Count distinct 问题引起的,因此在 ETL 开发工作中应该重视 Count Distict 问题,避免数据膨胀。对于一些表的 Join 阶段的 N 值问题,应该对表的数据分布要有清楚认识,在开发时解决这个问题 [^3]。 ### 合理处理大表关联小表 大表关联小表容易发生数据倾斜,可以将小表加载到内存中,使用 MapJoin 来避免数据倾斜。可以通过设置 `hive.auto.convert.join` 参数为 true 来开启自动转换 MapJoin,示例代码如下: ```sql SET hive.auto.convert.join = true; ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值