简答说一下hadoop的map-reduce编程模型?

发布于 2020-01-10 22:27:08
关注者
0
被浏览
629
1 个回答
  • 面试哥
    面试哥 2020-01-10
    为面试而生,有面试问题,就找面试哥。

    首先map task会从本地文件系统读取数据,转换成key-value形式的键值对集合。 将键值对集合输入mapper进行业务处理过程,将其转换成需要的key-value在输出。 之后会进行一个partition分区操作,默认使用的是hashpartitioner,可以通过重写hashpartitioner的getpartition方法来自定义分区规则。 之后会对key进行进行sort排序,grouping分组操作将相同key的value合并分组输出。 在这里可以使用自定义的数据类型,重写WritableComparator的Comparator方法来自定义排序规则,重写RawComparator的compara方法来自定义分组规则。 之后进行一个combiner归约操作,其实就是一个本地段的reduce预处理,以减小后面shufle和reducer的工作量。 reduce task会通过网络将各个数据收集进行reduce处理,最后将数据保存或者显示,结束整个job。

     

知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看