ich die folgende Fehlermeldung erhalten:Hadoop IO Fehler: Typenkonflikt in Schlüssel aus der Karte: erwartet org.apache.hadoop.io.Text erhielt RegexMatcher.CustomKey
java.lang.Exception: java.io.IOException: Type mismatch in key from map: expected org.apache.hadoop.io.Text, received RegexMatcher.CustomKey
at org.apache.hadoop.mapred.LocalJobRunner$Job.runTasks(LocalJobRunner.java:462)
at org.apache.hadoop.mapred.LocalJobRunner$Job.run(LocalJobRunner.java:522)
Caused by: java.io.IOException: Type mismatch in key from map: expected org.apache.hadoop.io.Text, received RegexMatcher.CustomKey
Zuerst definiere ich einen benutzerdefinierten Datentyp in Map-reduce CustomKey genannt:
public class CustomKey implements Writable {
public Text userId;
public Text friendId;
public CustomKey() {
this.userId = new Text();
this.friendId = new Text();
}
public CustomKey(String userId, String friendId) {
this.userId = new Text(userId);
this.friendId = new Text(friendId);
}
@Override
public void write(DataOutput out) throws IOException {
userId.write(out);
userId.write(out);
}
@Override
public void readFields(DataInput in) throws IOException {
userId.readFields(in);
friendId.readFields(in);
}
}
Dann erstelle ich einen Mapper SingleClassv2LogMapper
public static class SingleClassv2LogMapper extends Mapper<Object, Text, CustomKey, IntWritable> {
private final static IntWritable one = new IntWritable(1);
private Text word = new Text();
@Override
protected void map(Object key, Text value, Context context) throws IOException, InterruptedException {
Configuration conf = context.getConfiguration();
String regex = conf.get("regex");
String delimeter = conf.get("delimeter");
String currentLine = value.toString();
String tag = RingIdLogParser.parseHashTag(value.toString());
String body = RingIdLogParser.parseBody(value.toString());
if (tag != null) {
if (tag.equals(RegularExpressionBundle.updateMultipleMessageStatus)) {
CustomKey customKey = RingIdLogParser.parseUserFrinedInfo(body);
int messageNo = RingIdLogParser.getMessageCount(body);
context.write(customKey, new IntWritable(messageNo));
}
}
}
}
Und ein Reducer
public static class SingleClassv2LogReducer extends Reducer<CustomKey, IntWritable, Text, IntWritable> {
TextArrayWritable sum = new TextArrayWritable();
@Override
protected void reduce(CustomKey key, Iterable<IntWritable> values, Context context) throws IOException, InterruptedException {
int sum = 0;
for (IntWritable value : values) {
sum = sum + value.get();
}
String compactUser = key.userId.toString() +" "+ key.friendId.toString();
context.write(new Text(compactUser), new IntWritable(sum));
}
}
Was soll ich jetzt tun? Jeder hier, um mir zu helfen.
Der der Treiber-Code wie dieses ich die ähnlichen Problem konfrontiert waren
Configuration conf = new Configuration();
Job job = Job.getInstance(conf, "Regex Matcher");
job.setJarByClass(SingleClassLogDriverv2.class);
job.setMapperClass(SingleClassv2LogMapper.class);
job.setCombinerClass(SingleClassv2LogCombiner.class);
job.setReducerClass(SingleClassv2LogReducer.class);
job.setOutputKeyClass(Text.class);
job.setOutputValueClass(IntWritable.class);
job.setMapOutputKeyClass(CustomKey.class);
job.setMapOutputValueClass(IntWritable.class);
FileInputFormat.addInputPath(job, new Path(args[0]));
FileOutputFormat.setOutputPath(job, new Path(args[1]));
System.exit(job.waitForCompletion(true) ? 0 : 1);
sollten Sie Ihren Treiber freigeben –