MapReduce的shuffle阶段

Shuffle
为何需要shuffle
• Reduce阶段的数据来源于不同的Map
Shuffle由Map端和Reduce端组成
Shuffle的核心机制
• 数据分区+排序
Map端
• 对Map输出结果进行spill
Reduce端
• 拷贝Map端输出结果到本地
• 对拷贝的数据进行归并排序Shuffle Map端
Map端会源源不断的把数据输入到一个环形内存缓冲区
达到阈值(默认80%)时
• 新启动一个线程
• 把内存缓冲区的数据溢写到磁盘
在溢出的过程中
• Partitioner分组
• 对于每个组,按照key排序
Map处理完成后
• 对溢出到磁盘上的多个文件进行Merge操作
• 合并为一个大文件和一个索引文件Shuffle Reduce端
Map端完成之后后暴露一个Http Server给Reduce端获取数据使用
Reduce启动拷贝线程从各个Map端拷贝结果
• 大量的网络IO开销
一边拷贝一边进行Merge操作(归并排序)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值