java.io.IOException:Typemismatch in key from map:expected org.apache.hadoop.io

解决办法:       

            job.setMapOutputKeyClass(IntWritable.class);

            job.setMapOutputValueClass(Text.class);

            job.setOutputKeyClass(Text.class);

            job.setOutputValueClass(IntWritable.class);

 

 if (key.getClass() != keyClass) {
        thrownew IOException("Type mismatch in key from map: expected "
                             + keyClass.getName() + ", recieved "
                             + key.getClass().getName());
      }
      if(value.getClass() != valClass) {
        thrownew IOException("Type mismatch in value from map: expected "
                             + valClass.getName() + ", recieved "
                             + value.getClass().getName());
      }

在MapOutputBuffer.collet()会检查实际传过来的Key Value 类型,和MapOutputBuffer初始化指定的KeyClass和ValueClass是否一样。

keyClass= (Class<K>)job.getMapOutputKeyClass();

valClass =(Class<V>)job.getMapOutputValueClass();

 

public Class<?> getOutputKeyClass() {    return getClass("mapred.output.key.class",                    LongWritable.class, Object.class);  没用指定即采用默认的LongWritable  }
public Class<?> getOutputKeyClass() {    return getClass("mapred.output.key.class",                    LongWritable.class, Object.class);  没用指定即采用默认的LongWritable  }

上述是直接在程序中修改,还有一种在命令行中指定key和value的类型。

-D  mapred.mapoutput.key.class=org.apache.hadoop.io.LongWritable或者-jobconf mapred.mapoutput.key.class=org.apache.hadoop.io.LongWritable
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值