mapreduce的原理_深入理解redis

mapreduce的原理_深入理解redis1.MapReduce概念 1)MapReduce是一种分布式计算模型,由Google提出,主要用于搜索领域,解决海量数据的计算问题. 2)MapReduce是分布式运行的,由两个阶段组成:Map和R

MapReduce原理深入理解(一)

1.MapReduce概念

1)MapReduce是一种分布式计算模型,由Google提出,主要用于搜索领域,解决海量数据的计算问题.

2)MapReduce是分布式运行的,由两个阶段组成:Map和Reduce,Map阶段是一个独立的程序,有很多个节点同时运行,每个节点处理一部分数据。Reduce阶段是一个独立的程序,有很多个节点同时运行,每个节点处理一部分数据【在这先把reduce理解为一个单独的聚合程序即可】。

3)MapReduce框架都有默认实现,用户只需要覆盖map()和reduce()两个函数,即可实现分布式计算,非常简单。

4)两个函数的形参和返回值都是<key、value>,使用的时候一定要注意构造<k,v>。

2.MapReduce核心思想

mapreduce的原理_深入理解redis

 

 

 

(1)分布式的运算程序往往需要分成至少2个阶段。

 

(2)第一个阶段的MapTask并发实例,完全并行运行,互不相干。

 

(3)第二个阶段的ReduceTask并发实例互不相干,但是他们的数据依赖于上一个阶段的所有MapTask并发实例的输出。

 

(4)MapReduce编程模型只能包含一个Map阶段和一个Reduce阶段,如果用户的业务逻辑非常复杂,那就只能多个MapReduce程序,串行运行。

 

总结:分析WordCount数据流走向深入理解MapReduce核心思想。

 

 

 

 

mapreduce的原理_深入理解redis

 

 3. MapReduce 中的shuffle

mapreduce的原理_深入理解redis

 

 4.Mapreduce代码

import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.FileSystem; import org.apache.hadoop.fs.Path; import org.apache.hadoop.io.LongWritable; import org.apache.hadoop.io.Text; import org.apache.hadoop.mapreduce.Job; import org.apache.hadoop.mapreduce.Mapper; import org.apache.hadoop.mapreduce.Reducer; import org.apache.hadoop.mapreduce.lib.input.FileInputFormat; import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat; import java.io.IOException; public class WordCount { //分割任务 // 第一对kv,是决定数据输入的格式 // 第二队kv 是决定数据输出的格式
    public static class MyMapper extends Mapper<LongWritable, Text, Text, LongWritable> { /*map阶段数据是一行一行过来的 每一行数据都需要执行代码*/ @Override protected void map(LongWritable key, Text value, Context context) throws IOException, InterruptedException { LongWritable longWritable = new LongWritable(1); String s = value.toString(); context.write(new Text(s), longWritable); } } //接收Map端数据
    public static class MyReducer extends Reducer<Text, LongWritable, Text, LongWritable> { /* reduce 聚合程序 每一个k都会调用一次 * 默认是一个节点 * key:每一个单词 * values:map端 当前k所对应的所有的v */ @Override protected void reduce(Text key, Iterable<LongWritable> values, Context context) throws IOException, InterruptedException { //设置统计的初始值为0
            long sum = 0l; for (LongWritable value : values) { sum += value.get(); } context.write(key, new LongWritable(sum)); } } /** * 是当前mapreduce程序入口 * 用来构建mapreduce程序 */
    public static void main(String[] args) throws IOException, ClassNotFoundException, InterruptedException { //创建一个job任务
        Job job=Job.getInstance(); //指定job名称
        job.setJobName("第一个mr程序"); //构建mr //指定当前main所在类名(识别具体的类)
        job.setJarByClass(WordCount.class); //指定map端类 // 指定map输出的kv类型
        job.setMapperClass(MyMapper.class); job.setMapOutputKeyClass(Text.class); job.setMapOutputValueClass(LongWritable.class); //指定reduce端类 //指定reduce端输出的kv类型
        job.setReducerClass(MyReducer.class); job.setOutputKeyClass(Text.class); job.setOutputValueClass(LongWritable.class); // 指定输入路径
        Path in = new Path("/word"); FileInputFormat.addInputPath(job,in); //输出路径指定
        Path out = new Path("/output"); FileSystem fs = FileSystem.get(new Configuration()); //如果文件存在
        if(fs.exists(out)){ fs.delete(out,true); } //存在
 FileOutputFormat.setOutputPath(job,out); //启动
        job.waitForCompletion(true); System.out.println("MapReduce正在执行"); } }

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5832.html

(0)
上一篇 2023-04-22
下一篇 2023-04-23

相关推荐

  • 数据分析数据集网站_巨杉数据库优缺点

    数据分析数据集网站_巨杉数据库优缺点近日,作为新一代金融级分布式数据库,巨杉数据库凭借着在国产软件领域取得的瞩目成就,入选由德本咨询、eNet研究院和互联网周刊联合评选的“2020信创产业独角兽百强榜”。 信息技术创新是从核心到应用的…

    2023-03-08
    152
  • oracle内存占用过高和修改不当无法启动oracle实例的解决办法[通俗易懂]

    oracle内存占用过高和修改不当无法启动oracle实例的解决办法[通俗易懂]今天,在自己机器上装了oracle 12c,发现Oracle的服务Oracle RDBMS Kenel Executable (OracleServiceORCL)占用内存高达5G,本人电脑内存才16

    2022-12-21
    144
  • MySQL到底能有多少个字段[亲测有效]

    MySQL到底能有多少个字段[亲测有效]今天技术讨论群里 “一切随遇而安”同学看书时出现一个疑问,一个MySQL的表中到底可以有多少个字段?带着这个疑问,我们展开了探讨,也接着讨论了一个单字段长度的问题。 1. 官方文档说明 官方文档的内容

    2023-02-12
    151
  • TiDB 学习笔记一(运维管理)[通俗易懂]

    TiDB 学习笔记一(运维管理)[通俗易懂]1.截至 4.0 版本,TiDB 与 MySQL 的区别总结 功能 MySQL TiDB 隔离级别 支持读未提交、读已提交、可重复读、串行化。【默认为可重复读】 乐观事务支持快照隔离,悲观事务支持快照

    2023-04-20
    164
  • Python工程师必备:掌握numpy的load函数

    Python工程师必备:掌握numpy的load函数在Python的科学计算领域,numpy库是必不可少的。numpy中的load函数也是非常重要的一个函数,它可以方便地读取各种类型的文件,包括.npy、.npz等文件,并转换成numpy数组。本文将会从多个方面对numpy的load函数进行详细讲解,以便Python工程师能够轻松地熟练掌握这个函数,提高工作的效率。

    2024-05-25
    80
  • 如何退出vim编辑模式

    如何退出vim编辑模式Vi是一个很古老却也很强大的文本编辑器,Vim是Vi的增强版。在使用Vim编辑文件时,由于其非常特殊的编辑模式和操作方式,经常会导致新手遇到困难。尤其是在退出编辑模式时,可能会不小心关闭文件而没有保存,或者根本不知道如何退出编辑模式。本文将详细介绍如何正确地退出Vim编辑模式。

    2024-07-02
    45
  • 精准掌握Python rospy time的用法,轻松实现ROS系统时间控制

    精准掌握Python rospy time的用法,轻松实现ROS系统时间控制ROS(Robot Operating System)是一种面向机器人应用开发的操作系统,Python rospy是ROS中用于Python编写节点的常用工具,而time模块则是Python中用于获取当前时间等时间计算的标准模块之一。利用Python rospy和time模块,我们可以轻松地实现ROS系统的时间控制。

    2024-01-23
    113
  • SQL Server CTE的一些实用例子[通俗易懂]

    SQL Server CTE的一些实用例子[通俗易懂]一、引言 CTE(Common Table Expression) 公用表达式,它是在单个语句的执行范围内定义的临时结果集,只在查询期间有效。它可以自引用,也可在同一查询中多次引用,实现了代码段的重复

    2023-05-16
    192

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注