WordCount程序分析

本文详细解析了Hadoop的WordCount任务,将其类比为Java学习中的HelloWorld,深入探讨了Hadoop计算处理过程中的Map与Reduce函数,并介绍了支持数据传输和存储的关键数据类型。进一步分析了main函数的初始化过程、设置输出类型、处理类选择及输入输出路径配置。同时,对Map函数和Reduce函数进行了详细解释,展示了如何通过Map函数切分输入行并收集输出,以及Reduce函数如何合并结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Hadoop的WordCount相当于java学习中的Hallo World。

Hadoop的计算处理过程中的函数,可以高度抽象成map和reduce两步。map把任务分解成多个,reduce负责把结果汇总起来。

Hadoop提供了如下内容的数据类型,这些数据类型都实现了WritableComparable接口,以便用这些类型定义的数据可以被序列化进行网络传输和文件存储,以及进行大小比较。

 

    BooleanWritable:标准布尔型数值

    ByteWritable:单字节数值

    DoubleWritable:双字节数

    FloatWritable:浮点数

    IntWritable:整型数

    LongWritable:长整型数

    Text:使用UTF8格式存储的文本

    NullWritable:当<key,value>中的key或value为空时使用

main函数分析:

public static void main(String[] args) throws Exception {
    JobConf conf = new JobConf(WordCount.class);
    conf.setJobName("wordcount");

    conf.setOutputKeyClass(Text.class);
    conf.setOutputValueClass(IntWritable.class);

    conf.setMapperClass(Map.class);
    conf.setCombinerClass(Reduce.class);
    conf.setReducerClass(Reduce.class);

    conf.setInputFormat(TextInputFormat.class);
    conf.setOutputFormat(TextOutputFormat.class);

    FileInputFormat.setInputPaths(conf, new Path(args[0]));
    FileOutputFormat.setOutputPath(conf, new Path(args[1]));

    JobClient.runJob(conf);
}

首先对job进行初始化,

JobConf conf = new JobConf(WordCount. class );

conf.setJobName("wordcount" );

JobConf类对job进行初始化,然后conf.setJobName对job命名。

然后设置job输出结果中key哈value的数据类型

conf.setOutputKeyClass(Text.class );

conf.setOutputValueClass(IntWritable.class );

因为输出结果为 单词/个数,所以类型分别为text

设置Job处理的Map(拆分)、Combiner(中间结果合并)以及Reduce(合并)的相关处理类

conf.setMapperClass(Map.class );

conf.setCombinerClass(Reduce.class );

conf.setReducerClass(Reduce.class );


设置输入输出路径

conf.setInputFormat(TextInputFormat.class );
conf.setOutputFormat(TextOutputFormat.class );


Map函数分析

<span style="font-size:14px;">
   </span><span style="font-family:Microsoft YaHei;font-size:14px;"> public static class Map extends MapReduceBase implements /*继承</span><span style="font-family:Microsoft YaHei;font-size:14px;">MapReduceBase类</span><span style="font-family:Microsoft YaHei;font-size:14px;">*
            Mapper<LongWritable, Text, Text, IntWritable> { /*实现mapper接口*
        private final static IntWritable one = new IntWritable(1);
        private Text word = new Text();

        public void map(LongWritable key, Text value,
                OutputCollector<Text, IntWritable> output, Reporter reporter)
                throws IOException {
            String line = value.toString();
            StringTokenizer tokenizer = new StringTokenizer(line);
            while (tokenizer.hasMoreTokens()) {
                word.set(tokenizer.nextToken());
                output.collect(word, one);
            }
        }
    }
</span>

map方法对输入的行以空格为单位进行切分,然后使用OutputCollect收集输出的<word,one>


Reduce函数分析

public static class Reduce extends MapReduceBase implements/*继承MapReduceBase类* 
        Reducer<Text, IntWritable, Text, IntWritable> { /*实现Reducer接口*
    public void reduce(Text key, Iterator<IntWritable> values,
            OutputCollector<Text, IntWritable> output, Reporter reporter)
            throws IOException {
        int sum = 0;
        while (values.hasNext()) {
            sum += values.next().get();
        }
        output.collect(key, new IntWritable(sum));
    }
}
Reduce函数将输入的key值作为输出的key值,然后将获得多个value值加起来,作为输出的值.





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值