Hadoop0.20更新的示例分析

发布时间:2021-12-06 09:39:14 作者:小新
来源:亿速云 阅读:144

这篇文章将为大家详细讲解有关Hadoop0.20更新的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

Hadoop0.20更新笔记

最近学习hadoop0.20.1,网上找到一篇文章《What’sNewinHadoopCore0.20》,非完整的给翻译了一下,为以后检索方便,发上来保存一份。如果能读懂英文的,千万不要看下面的中文。

HadoopCore0.20.0在2009年4月22日发布。这一发布相对0.19发布,有很多用户使用层面上的改变。

Core
Hadoop中两个主要的组件是分布式文件系统(HDFS)和MapReduce,那两个组件分别挪入各自的子项目中,因此他们能拥有自己的发布周期,并且更容易对开发进行管理。但是在0.20发布中,这两个组件还是在一起发布。在这次发布中,hadoop-size.xml被拆分成三个配置文件:core-site.xml、hdfs-site.xml和mapred-site.xml(HADOOP-4631)。你也可以继续使用单一的hadoop-site.xml,hadoop仅仅会提出一个警告而已。默认配置文件已经移出conf文件夹,转而放到.jar文件中,其内容可以看docs文件夹中的html文件。不赞成start-all.sh、stop-all.sh的使用,建议使用start-dfs.sh、start-mapred.sh、stop-dfs.sh、stop-mapred.sh来代替。
上面说的是一些主要的变化,而允许slaves文件中加注注释(HADOOP-4454)对实际操作更为有用。
Hadoop配置文件支持Xinclude元素,用于引入其他的配置文件(HADOOP-4944(url:https://issues.apache.org/jira/browse/HADOOP-4944))。这一机制能让配置文件更加模块化、更易于重用。
围绕安全问题,hadoop作出了一系列动作。其中0.20.0增加了service-levelauthorization(HADOOP-4348)。开发人员能够限制客户端与hadoopdaemons的通信。
LZOcompressionlibraries因为许可的原因移出了hadoopcore,如果你的代码使用GPL许可证,你还是能从hadoop-gpl-compression项目中得到LZO。

HDFS
HSFSappend从0.19.1开始默认disable。
hadoop增加了一个新的管理命令:hadoopdfsadmin-saveNamespace。在安全模式下,这个命令能让namenode转存namespace到磁盘。

MapReduce
在Hadoop0.20更新中,***的变化是加入了一个叫“ContextObjects”的新JavaAPI。把Mapper和Reduce通过引入ContextObject变成抽象类(不是接口),是为了让API将来更易于演进。
1.JobConf不再存在,Job配置信息由Configuration持有;
2.现在在map()或reduce()方法中,更容易得到job配置信息。仅需要调用context.getConfiguration()。
3.新的API支持pull形式的迭代。在此之前,如果你想在mapper中遍历一下记录,你不得不把他们保存到Mapper类的实例变量中。在新的API中,只需要调用nextKeyValue()即可。
4.你还能覆盖run()方法,来控制mapper如何运行。
5.新API中不再有IdentityMapper和IdentityReducer两个类,因为默认Mapper和Reducer执行了标识函数。
新的API并非向后兼容,所以你必须重写你的应用。注意,新的API在org.apache.hadoop.mapreduce包及其子包中,而旧的API在org.apache.hadoop.mapred。
Multipletaskassignment,这一优化让JobTracker在一次心跳周期内能分配给tasktracker多个任务,提高了利用率。同时引入mapred.reduce.slowstart.completed.maps新的配置参数(默认0.05)。
Inputformats增加了一些有意思的改进。FileInputFormat在选择那个主机有更多的需要分割的文件上做的更好。在另一方面0.20引入了CombineFileInputFormat类,他能把许多小文件变成一个split。
Gridmix2是第二代MapReduce工作量基准模型套件。

Contrib
两个新捐献的模块在0.20分支中出现:
HDFSProxy,他能暴露HDFS一个只读的HSFTP接口,用于提供安全的、只读的访问。
Vaidya,这是一个工具,用于在MapReducejob运行后通过检查作业历史和配置信息来诊断错误。针对常见的问题能提供一些改进意见,使得你的代码能避免出错。

关于“Hadoop0.20更新的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

推荐阅读:
  1. Postgres-XL更新的示例分析
  2. mysql中更新锁与排它锁的示例分析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

上一篇:spring+hibernate文件上传并放入大字段怎么实现

下一篇:Spring,hibernate,struts的面试笔试题有哪些

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》