zoukankan      html  css  js  c++  java
  • MapReduce编程实例3

    MapReduce编程实例:

    MapReduce编程实例(一),详细介绍在集成环境中运行第一个MapReduce程序 WordCount及代码分析

    MapReduce编程实例(二),计算学生平均成绩

    MapReduce编程实例(三),数据去重

    MapReduce编程实例(四),排序

    MapReduce编程实例(五),MapReduce实现单表关联

     

    输入:

    2013-11-01 aa
    2013-11-02 bb
    2013-11-03 cc
    2013-11-04 aa
    2013-11-05 dd
    2013-11-06 dd
    2013-11-07 aa
    2013-11-09 cc
    2013-11-10 ee

    2013-11-01 bb 
    2013-11-02 33 
    2013-11-03 cc
    2013-11-04 bb
    2013-11-05 23 
    2013-11-06 dd
    2013-11-07 99 
    2013-11-09 99
    2013-11-10 ee

    .....

    .....

    .....

    数据重复,map中每一行做为一个key,value值任意,经过shuffle之后输入到reduce中利用key的唯一性直接输出key

    代码太简单,不解释,上代码:

    [java] view plain copy
     
    1. package com.t.hadoop;  
    2.   
    3. import java.io.IOException;  
    4. import java.util.HashSet;  
    5. import java.util.StringTokenizer;  
    6.   
    7. import org.apache.hadoop.conf.Configuration;  
    8. import org.apache.hadoop.fs.Path;  
    9. import org.apache.hadoop.io.Text;  
    10. import org.apache.hadoop.mapreduce.Job;  
    11. import org.apache.hadoop.mapreduce.Mapper;  
    12. import org.apache.hadoop.mapreduce.Reducer;  
    13. import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;  
    14. import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;  
    15. import org.apache.hadoop.util.GenericOptionsParser;  
    16.   
    17. /** 
    18.  * 数据去重 
    19.  * @author daT dev.tao@gmail.com 
    20.  * 
    21.  */  
    22. public class Dedup {  
    23.   
    24.     public static class MyMapper extends Mapper<Object, Text, Text, Text>{  
    25.   
    26.         @Override  
    27.         protected void map(Object key, Text value, Context context)  
    28.                 throws IOException, InterruptedException {  
    29.                 context.write(value, new Text(""));  
    30.         }  
    31.     }  
    32.       
    33.     public static class MyReducer extends Reducer<Text, Text, Text, Text>{  
    34.   
    35.         @Override  
    36.         protected void reduce(Text key, Iterable<Text> value,  
    37.                 Context context)  
    38.                 throws IOException, InterruptedException {  
    39.             context.write(key, new Text(""));  
    40.         }  
    41.     }  
    42.       
    43.       
    44.     public static void main(String[] args) throws IOException, ClassNotFoundException, InterruptedException{  
    45.         Configuration conf = new Configuration();  
    46.         String[] otherArgs = new GenericOptionsParser(conf, args).getRemainingArgs();  
    47.           
    48.         if(otherArgs.length<2){  
    49.             System.out.println("parameter errors!");  
    50.             System.exit(2);  
    51.         }  
    52.           
    53.         Job job = new org.apache.hadoop.mapreduce.Job(conf, "Dedup");  
    54.         job.setJarByClass(Dedup.class);  
    55.         job.setMapperClass(MyMapper.class);  
    56.         job.setCombinerClass(MyReducer.class);  
    57.         job.setReducerClass(MyReducer.class);  
    58.         job.setOutputKeyClass(Text.class);  
    59.         job.setOutputValueClass(Text.class);  
    60.           
    61.         FileInputFormat.addInputPath(job, new Path(otherArgs[0]));  
    62.         FileOutputFormat.setOutputPath(job, new Path(otherArgs[1]));  
    63.           
    64.         System.exit(job.waitForCompletion(true)?0:1);  
    65.           
    66.     }  
    67.       
    68. }  
    输出结果
    2013-11-01 aa
    2013-11-01 bb 
    2013-11-02 33 
    2013-11-02 bb
    2013-11-03 cc
    2013-11-03 cc 
    2013-11-04 98
    2013-11-04 aa
    2013-11-04 bb
    2013-11-05 23 
    2013-11-05 93
    2013-11-05 dd
    2013-11-06 99
    2013-11-06 dd
    2013-11-07 92
    2013-11-07 99 
    2013-11-07 aa
    2013-11-09 99
    2013-11-09 aa 
    2013-11-09 cc
    2013-11-10 ee

    版权声明:本文为博主原创文章,未经博主允许不得转载。
  • 相关阅读:
    冒泡排序python实现
    mysql主从配置
    函数当作参数传递
    使用xml.dom.minidom创建xml
    php得到所有的汉字
    Cannot load D:/phpenv/php/php548/php5apache2_2.dll错误解决
    php新特性 traits 简单方法复用
    【转】在 Windows 下为 PHP 5.4 安装 PEAR、PHPUnit 及 phpDoc2
    wxpython基础框架
    MFC中文档视图框架和文档模板之间的关系
  • 原文地址:https://www.cnblogs.com/gaochsh/p/7802377.html
Copyright © 2011-2022 走看看