Spark性能调优之shuffle原理

本文介绍了Spark中的shuffle原理,包括shuffle的发生场景,如groupByKey、reduceByKey等操作。详细阐述了shuffle过程,从数据集中到同一节点,到reduce操作,再到shuffle过程中文件的生成和task之间的数据拉取。最后强调了shuffle对stage划分的影响以及内存缓冲和磁盘溢写的过程。
摘要由CSDN通过智能技术生成
shuffle原理概述:
哪些情况下,spark会发生shuffle?

spark中,以下几个算子会发生shuffle: groupByKey、reduceByKey、countByKey、join 等等

什么是shuffle?

groupByKey 就是把分散在集群上各个节点上的同一个key的数据,对应的values,集中到集群中同一个节点上。更准确的说,是集中到一个节点的一个executor的一个task中。集中了一个key的values后,才能继续做逻辑处理。

reduceByKey 对values集合进行reduce操作,最后变成一个value。

countByKey 在一个task中,获取一个key对应的所有values,然后进行计数。

举例reduceByKey(如下图):

在这里插入图片描述
同一个单词,比如(hello ,1),可能散落在不同的节点上;对单词计数累加时,就必须要让同一个单词在同一节点的一个task上,给一个task处理。

shuffle的前半部分stage的每个task,都会创建和下一个stage的task数量相同的文件。比如:下一个stage会有100个task,那么当前stage每一个task都会创建100份文件,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值