首页 > 其他 > 详细

Hadoop源代码分析(包hadoop.mapred中的MapReduce接口)

时间:2015-05-25 20:42:28      阅读:201      评论:0      收藏:0      [点我收藏+]

前面已经完成了对org.apache.hadoop.mapreduce的分析,这个包提供了Hadoop MapReduce部分的应用API,用于用户实现自己的MapReduce应用。但这些接口是给未来的MapReduce应用的,目前MapReduce框架还是使用老系统(参考补丁HADOOP-1230)。下面我们来分析org.apache.hadoop.mapred,首先还是从mapred的MapReduce框架开始分析,下面的类图(灰色部分为标记为@Deprecated的类/接口):


技术分享 

我们把包mapreduce的类图附在下面,对比一下,我们就会发现,org.apache.hadoop.mapred中的MapReduce API相对来说很简单,主要是少了和Context相关的类,那么,好多在mapreduce中通过context来完成的工作,就需要通过参数来传递,如Map中的输出,老版本是:
      output.collect(key,result);  // output’s type is:OutputCollector
新版本是:

      context.write(key, result);  // output’s type is: Context

它们分别使用OutputCollectorMapper.Context来输出map的结果,显然,原有OutputCollector的新API中就不再需要。总体来说,老版本的API比较简单,MapReduce过程中关键的对象都有,但可扩展性不是很强。同时,老版中提供的辅助类也很多,我们前面分析的FileOutputFormat,也有对应的实现,我们就不再讨论了。

更多精彩内容请关注:http://bbs.superwu.cn 

关注超人学院微信二维码:技术分享


Hadoop源代码分析(包hadoop.mapred中的MapReduce接口)

原文:http://crxy2013.blog.51cto.com/9922445/1654952

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!