Hadoop基本的Map/Reduce

HelloHadoop.class

 

Mapper

static public class HelloMapper extends Mapper<LongWritable, Text, LongWritable, Text> {
    public void map(LongWritable key, Text value, Context context) {
        context.write((LongWritable)key, (Text)value);
    }
}

<LongWritable, Text, LongWritable, Text>中的第一个LongWritable和第一个Text为Mapper的输入数据类型,第二个LongWritable和Text为Mapper的输出数据类型。

 

Reducer

static public class HelloReducer extends Reducer<LongWritable, Text, L ongWritable, Text> {
    public void reduce(LongWritable key, Iterable<Text> values, Context context) {
        Text val = new Text();
        for (Text str : values) {
            val.set(str.toString());
        }
        context.write(key, val);
    }
}

<LongWritable, Text, LongWritable, Text>中的第一个LongWritable和第一个Text为Reducer的输入数据类型,第二个LongWritable和Text为Reducer的输出数据类型。

 

Main

public static void main(String[] args) {
    Configuration conf = new Configuration();
    Job job = new Job(conf, "Hadoop Hello World");
    job.setJarByClass(HelloHadoop.class);
    FileInputFormat.setInputPaths(job, "input");
    FileOutputFormat.setOutputPath(job, new Path("output"));
    job.setMapperClass(HelloMapper.class);
    job.setReducerClass(HelloReducer.class);
    job.waitForCompletion(true);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值