簡體   English   中英

Hadoop自定義Mapper輸出格式到Reducer

[英]Hadoop custom Mapper output format to Reducer

HDFS的新手:

如果我錯了,請糾正我,但據我所知:

Mapper<Object, Text, Text, Text>

最后兩個Text是Mapper的返回類型。 說我想返回Text, <Text, IntWriteable> 我怎樣才能做到這一點? 另外,我在文檔中應該看什么?

例如,映射器接收到對象和文本后,會對輸入文件中的數據行進行一些邏輯處理,我希望它返回類似

context.write(Text,[Text, IntWriteable])

您可能需要定義自己的數據類型。 如果需要比較操作,請實現WritableComparable接口,否則只需實現Writable接口即可。

這是使用WritableComparable接口的示例:

public class MyDataType implements WritableComparable<MyDataType> {
    private Text name;
    private IntWritable age;

    @Override
    public void readFields(DataInput in) throws IOException {
        name.readFields(in);
        age.readFields(in);
    }

    @Override
    public void write(DataOutput out) throws IOException {
        name.write(out);
        age.write(out);
    }

    @Override
    public int compareTo(MyDataType o) {
        int nameCompare = name.compareTo(o.name);
        if(nameCompare != 0) {
            return nameCompare;
        } else {
            return age.compareTo(o.age);
        }
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM