hive 使用json格式在mapreduce时报错问题

hive 使用json格式在mapreduce时报错问题

hive java.lang.ClassNotFoundException: Class org.apache.hive.hcatalog.data.JsonSerDe not found

hadoop    | Error: java.lang.RuntimeException: Error in configuring object
hadoop    |     at org.apache.hadoop.util.ReflectionUtils.setJobConf(ReflectionUtils.java:113)
hadoop    |     at org.apache.hadoop.util.ReflectionUtils.setConf(ReflectionUtils.java:79)
hadoop    |     at org.apache.hadoop.util.ReflectionUtils.newInstance(ReflectionUtils.java:137)
hadoop    |     at org.apache.hadoop.mapred.MapTask.runOldMapper(MapTask.java:455)
hadoop    |     at org.apache.hadoop.mapred.MapTask.run(MapTask.java:343)
hadoop    |     at org.apache.hadoop.mapred.YarnChild$2.run(YarnChild.java:177)
hadoop    |     at java.security.AccessController.doPrivileged(Native Method)
hadoop    |     at javax.security.auth.Subject.doAs(Subject.java:422)
hadoop    |     at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1886)
hadoop    |     at org.apache.hadoop.mapred.YarnChild.main(YarnChild.java:171)
hadoop    | Caused by: java.lang.reflect.InvocationTargetException
hadoop    |     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
hadoop    |     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
hadoop    |     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
hadoop    |     at java.lang.reflect.Method.invoke(Method.java:498)
hadoop    |     at org.apache.hadoop.util.ReflectionUtils.setJobConf(ReflectionUtils.java:110)
hadoop    |     ... 9 more
hadoop    | Caused by: java.lang.RuntimeException: Error in configuring object
hadoop    |     at org.apache.hadoop.util.ReflectionUtils.setJobConf(ReflectionUtils.java:113)
hadoop    |     at org.apache.hadoop.util.ReflectionUtils.setConf(ReflectionUtils.java:79)
hadoop    |     at org.apache.hadoop.util.ReflectionUtils.newInstance(ReflectionUtils.java:137)
hadoop    |     at org.apache.hadoop.mapred.MapRunner.configure(MapRunner.java:38)
hadoop    |     ... 14 more
hadoop    | Caused by: java.lang.reflect.InvocationTargetException
hadoop    |     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
hadoop    |     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
hadoop    |     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
hadoop    |     at java.lang.reflect.Method.invoke(Method.java:498)
hadoop    |     at org.apache.hadoop.util.ReflectionUtils.setJobConf(ReflectionUtils.java:110)
hadoop    |     ... 17 more
hadoop    | Caused by: java.lang.RuntimeException: Map operator initialization failed
hadoop    |     at org.apache.hadoop.hive.ql.exec.mr.ExecMapper.configure(ExecMapper.java:137)
hadoop    |     ... 22 more
hadoop    | Caused by: org.apache.hadoop.hive.ql.metadata.HiveException: java.lang.ClassNotFoundException: Class org.apache.hive.hcatalog.data.JsonSerDe not found
hadoop    |     at org.apache.hadoop.hive.ql.exec.MapOperator.getConvertedOI(MapOperator.java:328)
hadoop    |     at org.apache.hadoop.hive.ql.exec.MapOperator.setChildren(MapOperator.java:420)
hadoop    |     at org.apache.hadoop.hive.ql.exec.mr.ExecMapper.configure(ExecMapper.java:106)
hadoop    |     ... 22 more
hadoop    | Caused by: java.lang.ClassNotFoundException: Class org.apache.hive.hcatalog.data.JsonSerDe not found
hadoop    |     at org.apache.hadoop.conf.Configuration.getClassByName(Configuration.java:2299)
hadoop    |     at org.apache.hadoop.hive.ql.plan.PartitionDesc.getDeserializer(PartitionDesc.java:177)
hadoop    |     at org.apache.hadoop.hive.ql.exec.MapOperator.getConvertedOI(MapOperator.java:295)
hadoop    |     ... 24 more
hadoop    |
hadoop    |
hadoop    | FAILED: Execution Error, return code 2 from org.apache.hadoop.hive.ql.exec.mr.MapRedTask
hadoop    | MapReduce Jobs Launched:
hadoop    | Stage-Stage-1: Map: 1  Reduce: 1   HDFS Read: 0 HDFS Write: 0 FAIL
hadoop    | Total MapReduce CPU Time Spent: 0 msec

解决方法:
方法一:添加add hive-hcatalog-core包(这个方法只在当次进入hive-cli有效,退出后再进入无效)
ADD JAR /usr/local/hive/lib/hive-hcatalog-core-2.3.2.jar;

方法二:Jar放入${HIVE_HOME}/auxlib目录(这个方法需重新再进hive-cli才会有效)
在${HIVE_HOME}建立一个auxlib目录,把hive-hcatalog-core.xxx.jar放到auxlib目录,重启hiverserver2,成功显示OK

参考链接:https://www.cnblogs.com/lfm601508022/p/9188819.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值