spark join 算法

Spark提供了五种执行Join操作的机制,分别是:

Shuffle Hash Join --
	key的哈希值,对两个数据集进行重新分区,使得两个数据集中key的哈希值相同的记录会被分配到同一个executor上
Broadcast Hash Join -- 
	较小的数据集会被广播到所有Spark的executor上,并转化为一个Hash Table,之后较大数据集的各个分区会在各个executor上与Hash Table进行本地的Join,各分区Join的结果合并为最终结果
数据传输流程 data->executor->driver-> broadcast  executor
Sort Merge Join--
	将key相同的记录重分配同一个executor上,不同的是,在每个executor上,不再构造哈希表,而是对两个分区进行排序,然后用两个下标同时遍历两个分区
Cartesian Join
Broadcast Nested Join--
	将一个输入数据集广播到每个executor上,然后在各个executor上,另一个数据集的分区会和第一个数据集使用嵌套循环的方式进行Join输出结果
Spark中的join操作有多种实现策略,包括Shuffle Hash Join(洗牌哈希连接)、Broadcast Hash Join(广播哈希连接)、Sort Merge Join(排序合并连接)、Cartesian Join(笛卡尔连接)和Broadcast Nested Loop Join(广播嵌套循环连接)。 Shuffle Hash JoinSpark中的默认join策略,它将两个数据集根据连接键进行分区,并将相同连接键的数据发送到同一个分区。然后,通过哈希函数将两个数据集的相同连接键的数据分布到相同的节点上,并进行连接操作。这种策略适用于大规模数据集的连接操作,但可能会产生大量的网络传输和数据洗牌操作。 Broadcast Hash Join适用于一个小数据集和一个大数据集进行连接操作的场景。它将小数据集广播到所有的工作节点,然后使用哈希连接算法大数据集与每个节点上的小数据集进行连接。由于小数据集被广播到每个节点,这种策略减少了数据洗牌的开销,提高了性能。 Sort Merge Join是一种通过对两个数据集进行排序后进行合并的连接策略。它适用于两个数据集都已经排序或者无法广播的情况。Sort Merge Join首先对两个数据集根据连接键进行排序,然后按照连接键进行合并操作。这种策略需要额外的排序操作,但可以避免数据洗牌。 Cartesian Join是一种比较低效的连接策略,它将两个数据集的每一条记录都与另一个数据集的所有记录进行连接。这种策略适用于小规模数据集的连接操作,但可能会导致数据爆炸和性能下降。 Broadcast Nested Loop Join是一种在嵌套循环连接的基础上使用广播的优化策略。它将一个小数据集广播到所有的工作节点,并在每个节点上执行嵌套循环连接操作。这种策略适用于一个小数据集和一个大数据集进行连接的场景,可以提高性能。 总的来说,Spark中的join操作根据数据集的大小、排序状态和网络传输等因素选择合适的实现策略来进行连接操作,以提高性能和效率。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Spark SQL 之 Join原理](https://blog.csdn.net/weixin_42868529/article/details/104521847)[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: 50%"] - *2* *3* [SparkJoin实现原理](https://blog.csdn.net/jinjiating/article/details/127973403)[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: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值