自定义WritableComparable问题 - 永远不会调用reducer

时间:2016-05-27 15:48:15

标签: java hadoop mapreduce mapper reducers

驱动程序类

public class abdDriver {

    public static void main(String arg[]) {
        try {
            Path input = new Path("amazon.txt");
            Path output = new Path("./outPutData");

            Configuration conf = new Configuration();
            Job job = Job.getInstance(conf);
            job.setJarByClass(abdDriver.class);

            job.setMapperClass(abdMapper.class);
            job.setMapOutputKeyClass(LongWritable.class);
            job.setMapOutputValueClass(Text.class);


            job.setReducerClass(abdReducer.class);
            job.setOutputKeyClass(NullWritable.class);
            job.setOutputValueClass(Text.class);


            job.setInputFormatClass(abdRecordReader.class);
            //job.setOutputFormatClass(TextOutputFormat.class);

            FileInputFormat.addInputPath(job, input);
            FileOutputFormat.setOutputPath(job, output);

            output.getFileSystem(job.getConfiguration()).delete(output, true);

            job.waitForCompletion(true);

            System.out.println("Completed successfully");

        } catch (Exception e) {
            System.out.println(e.getMessage());
        }
    }
}

Mapper Class

public class abdMapper extends Mapper<LongWritable, abdRecordClass, LongWritable, Text> {

    @Override
    public void map(LongWritable key, abdRecordClass value, Context con) throws IOException, InterruptedException {
        if (value.getTITLE().toString().trim().length() > 0) {
            con.write(key, value.getTITLE());
            System.out.println(key + "\t" + value.getTITLE() + "\t" + value.getCATEGORIES());
        }
    }
}

Reducer Class

public class abdReducer extends Reducer<LongWritable, Text, NullWritable, Text> {

    @Override
    public void reduce(LongWritable key, Iterable<Text> value, Context con) throws IOException, InterruptedException {
        System.out.println("reducer");

        for (Text t : value) {
            System.out.println(t);
            con.write(NullWritable.get(), t);
        }
    }

}

custom writablecomparable class

public class abdRecordClass implements WritableComparable<abdRecordClass> {

    private Text ID, ASIN, TITLE, GROUP, SALESRANK, REV_SUMMARY,

    SIMILAR, CATEGORIES, REVIEWS;

    public abdRecordClass() {
        ID = new Text();
        ASIN = new Text();
        TITLE = new Text();
        GROUP = new Text();
        SALESRANK = new Text();
        REV_SUMMARY = new Text();
        SIMILAR = new Text();
        CATEGORIES = new Text();
        REVIEWS = new Text();
        ;
    }

    public abdRecordClass(Text id, Text asin, Text title, Text group, Text rank, Text similar, Text cat, Text rev_summary, Text reviews) {
        super();
        this.ID = id;
        this.ASIN = asin;
        this.TITLE = title;
        this.GROUP = group;
        this.SALESRANK = rank;
        this.SIMILAR = similar;
        this.CATEGORIES = cat;
        this.REV_SUMMARY = rev_summary;
        this.REVIEWS = reviews;
        System.out.println("new record created");
    }

    @Override
    public void readFields(DataInput in) throws IOException {
        System.out.println("read fields");
        this.ID.readFields(in);
        this.ASIN.readFields(in);
        this.TITLE.readFields(in);
        this.GROUP.readFields(in);
        this.SALESRANK.readFields(in);
        this.SIMILAR.readFields(in);
        this.CATEGORIES.readFields(in);
        this.REV_SUMMARY.readFields(in);
        this.REVIEWS.readFields(in);

    }

    @Override
    public void write(DataOutput out) throws IOException {

        this.ID.write(out);
        System.out.println("write fields");
        this.ASIN.write(out);
        this.TITLE.write(out);
        this.GROUP.write(out);
        this.SALESRANK.write(out);
        this.SIMILAR.write(out);
        this.CATEGORIES.write(out);
        this.REV_SUMMARY.write(out);
        this.REVIEWS.write(out);

    }
}

问题是: 代码工作正常到mapper,因为mapper中的sysout提供了完美的输出,但是在mapper reducer之后我们永远不会被调用。 writeablecomparable类有什么问题吗?

0 个答案:

没有答案