map和reduce

map和reduce

在整个的MapReduce任务过程中,可以分为两个阶段:map阶段和reduce阶段。并map阶段和reduce阶段通过shuffle来进行连接。

map阶段和reduce阶段两个阶段都以键-值对的形式作为输入和输出的类型。并且,该类型由程序员根据实际的需求来进行选择。程序员还需要给map阶段和reduce阶段写两个函数:map函数和reduce函数。

map函数是数据准备阶段,通过map函数对数据进行准备后,由reduce函数来进行数据处理。

  • map函数阶段:

    • 输入内容:完整的数据集文件。

    • 函数功能:将输入的数据集中每个后续要用到的字段数据提取出来,筛掉没用的、缺失的、可疑的和明显错误的数据。并将筛选好的数据整理为K-V类型。

      K-V类型:

      • 其中K得值应具有确定型,就像数据库中的主键(不必唯一),便于后续阶段的数据分组处理的索引。
      • 其中V得值为后续阶段需要判断的数据内容。

      以各班学生的身高举例,输出应为:

      {(1, 172), (1, 177), (1, 188), (2, 178), (1, 202), (3, 198), (4, 199), (2, 198)}

    • 输出内容:将整理好的K-V类型数据列表。(将作为reduce函数的输入)

  • reduce函数阶段:

    • 输入内容:map阶段输出的K-V类型。
    • 函数功能:按照项目要求,对输入的K-V列表进行相应的要求操作。
    • 输出内容:要求输出的结果。

笔记内容为作者学习总结,欢迎大家交流探讨,如有侵权,联系作者。
更多内容请关注公众号:玖柒壹点点

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值