优化Spark中的数据倾斜

介绍

数据倾斜是统计术语,反应在数据集中的值分布情况。当数据是高度倾斜时,表示一些列值拥有更多的行,而一些拥有更少的行。值没有平均分配,这样在分布式系统中会造成性能问题。
在这里插入图片描述

join多张拥有数据倾斜问题的表

在Spark中join多张拥有数据倾斜问题的表,可能会出现卡在最后的stage(399/400),当超过一定时间后,会报Caused by: org.apache.spark.shuffle.FetchFailedException: Too large frame: 7498008366错误。
例子如下:

-- Sample query where we are joining on highly null columns
select * 
from  order_tbl orders left join customer_tbl  customer
      on orders.customer_id = customer.customer_id
      left join delivery_tbl delivery
      on  orders.delivery_id = delivery.delivery_id

表统计如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值