Hadoop学习之MapReduce(一)

本文介绍了MapReduce的原理和工作流程,包括其在大规模数据处理中的角色,以及如何通过Map和Reduce函数处理数据。文章提到了MapReduce作业的输入输出形式,并详细解释了Hadoop的WordCount示例,展示了一个MapReduce程序的编写和执行过程。

在学习过了HDFS架构和Hadoop的配置管理后,现在学习MapReduce应用程序的编写和管理。首先简单介绍一下MapReduce框架。

MapReduce是一个易于编写程序的软件框架,这些应用程序以可靠的、容错的模式并行的运行在很大规模的商用硬件集群上(数以千计的节点),处理超大数量的数据(超过TB的数据集)。一个MapReduce作业通常将输入数据集分割为独立的数据块,这些数据块被map任务以完全并行的方式处理,MapReduce框架整理map任务的输出结果,然后map的输出结果做为reduce任务的输入。典型地,作业的输入和输出都存储在文件系统中。MapReduce框架处理调度任务,监控任务和重新执行失败的任务。

通常地,计算节点和存储节点是相同的节点,也就是MapReduce框架和HDFS运行在相同的节点集之上。这种配置方式允许MapReduce框架在数据存放的节点上有效地调度任务,导致集群中非常高的带宽传输率。MapReduce由单一的主JobTracker和每个集群节点上一个的从TaskTracker组成。主节点负责调度作业在从节点上的组件任务,监控任务和重新执行失败的任务,从节点执行由主节点指示的任务。

最低限度地,应用程序指定输入输出位置,通过实现恰当地的接口和(或者)抽象类提供map和reduce函数,这些信息和其它的作业参数组成了作业的配置管理(jobconfiguration)。Hadoop的作业客户端提交作业(jar文件或者可执行文件等)和JobTrackerde 配置信息,JobTracker开始承担分发软件/配置信息到从节点上,调度任务和监控任务,向作业客户端提供状态和诊断信息。

虽然Hadoop框架是用Java语言实现的,但是MapReduce应用程序不是必须用Java编写

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

skyWalker_ONLY

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值