趋势网 > 资讯 > 正文
版权归原作者所有 侵权敬请通知移除
摘要:map()函数把输入数据进行切割(比如分为M块)之后,分布到不同的机器上执行(例如前面介绍的单词统计例子,可以把每一个文件分配到一台机器上执行)。Reduce()函数通过产生的键key(例如可以根据某种分区函数(比如hash(key) mod R),R的值和分区函数都是由用户指定)将map()的结果集分成R块,然后分别在R台机器上执行。
男子切到手晕血边晕边爬去医院
网友:到医院发现手指是最轻的病。
游客因拍照设备太专业被景区驱赶
网友:商拍就是影响普通游客。
胖东来称若检测无错会起诉博主
网友:食品安全就要有较真的精神。
伊朗首都巨大爆 炸
网友:美国总是做着与说话相反的事。
黑龙江海林楼房坍塌致7死
网友:房屋老化早该拆迁整改了吧……愿逝者安息。
主人回应7只被偷小狗结伴逃回家
网友:看了好想哭怎么办,一生一世好朋友啊。

趋势网讯:

map()函数把输入数据进行切割(比如分为M块)之后,分布到不同的机器上执行(例如前面介绍的单词统计例子,可以把每一个文件分配到一台机器上执行)。Reduce()函数通过产生的键key(例如可以根据某种分区函数(比如hash(key) mod R),R的值和分区函数都是由用户指定)将map()的结果集分成R块,然后分别在R台机器上执行。

图1是MapReduce算法示意图。当用户程序调用MapReduce函数时,就会引起如下的操作。

,互联网,详解MapReduce算法及视图

图1

(1) MapReduce函数库首先把输入文件分成M块,每块大概16MB到64MB。接着在集群的机器上执行处理程序。

如图2.14所示,MapReduce算法运行过程中有一个主控程序,称为master。主控程序会产生很多作业程序,称为worker。并且把M个map任务和R个reduce任务分配给这些worker,让它们去完成。

(2) 被分配了map任务的worker读取并处理相关的输入(这里的输入是指已经被切割的输入小块splite)。它处理输入的数据,并且 将分析出的键/值(key/value)对传递给用户定义的reduce()函数。map()函数产生的中间结果键/值(key/value)对暂时缓冲 到内存。

(3) map()函数缓冲到内存的中间结果将被定时刷写到本地硬盘,这些数据通过分区函数分成R个区。这些中间结果在本地硬盘的位置信息将被发送回master,然后这个master负责把这些位置信息传送给reduce()函数的worker。

(4) 当master通知了reduce()函数的worker关于中间键/值(key/value)对的位置时,worker调用远程方法 从map()函数的worker机器的本地硬盘上读取缓冲的中间数据。当reduce()函数的worker读取到了所有的中间数据,它就使用这些中间数 据的键(key)进行排序,这样可以使得相同键(key)的值都在一起。如果中间结果集太大了,那么就需要使用外排序。

(5) reduce()函数的worker根据每一个中间结果的键(key)来遍历排序后的数据,并且把键(key)和相关的中间结果值(value)集合传递给reduce()函数。reduce()函数的worker最终把输出结果存放在master机器的一个输出文件中。

(6) 当所有的map任务和reduce任务都已经完成后,master激活用户程序。在这时,MapReduce返回用户程序的调用点。

(7) 当以上步骤成功结束以后,MapReduce的执行数据存放在总计R个输出文件中(每个输出文件都是由reduce任务产生的,这些文 件名是用户指定的)。通常,用户不需要将这R个输出文件合并到一个文件,他们通常把这些文件作为输入传递给另一个MapReduce调用,或者用另一个分 布式应用来处理这些文件,并且这些分布式应用把这些文件看成为输入文件由于分区(partition)成为的多个块文件。

美特种部队数百人抵达中东
网友:不要小看一个国家人民的集体意志。
董事长病逝未成年女儿继承9亿股票
网友:刚出生就在罗马,未成年直接继承9亿股票,这起点我一辈子追不上。
坠江身亡研究生离世前疑似发布遗言
网友:最后那点光还留给了患者,令人动容。
阿富汗称巴空袭摧毁医院致400死
网友:一个小小的巴基斯坦都敢侵略空袭邻国,不愧是美国盟友。
鹿哈或需赔偿消费者26.9亿元
网友:这种带货的我都不咋敢买,营销费用越大,生产费用越小。
重庆一隧道爆 炸致4人死亡
网友:应该突出在建遂道,并不是通车在使用的。
  感谢各大网址导航推荐本站: