首页 > 其他 > 详细

hive解析lzo文件失败,No LZO codec found, cannot run

时间:2015-11-22 02:07:32      阅读:657      评论:0      收藏:0      [点我收藏+]

Hive创建外部表,指向lzo格式文件时,无法解析出数据,报错如下:

java.io.IOException: No LZO codec found, cannot run.

hiveserver2日志报错如下:

Diagnostic Messages for this Task:
Error: java.io.IOException: java.lang.reflect.InvocationTargetException
?at org.apache.hadoop.hive.io.HiveIOExceptionHandlerChain.handleRecordReaderCreationException(HiveIOExceptionHandlerChain.java:97)
?at org.apache.hadoop.hive.io.HiveIOExceptionHandlerUtil.handleRecordReaderCreationException(HiveIOExceptionHandlerUtil.java:57)
?at org.apache.hadoop.hive.shims.HadoopShimsSecure$CombineFileRecordReader.initNextRecordReader(HadoopShimsSecure.java:265)
?at org.apache.hadoop.hive.shims.HadoopShimsSecure$CombineFileRecordReader.<init>(HadoopShimsSecure.java:212)
?at org.apache.hadoop.hive.shims.HadoopShimsSecure$CombineFileInputFormatShim.getRecordReader(HadoopShimsSecure.java:332)
?at org.apache.hadoop.hive.ql.io.CombineHiveInputFormat.getRecordReader(CombineHiveInputFormat.java:721)
?at org.apache.hadoop.mapred.MapTask$TrackedRecordReader.<init>(MapTask.java:169)
?at org.apache.hadoop.mapred.MapTask.runOldMapper(MapTask.java:432)
?at org.apache.hadoop.mapred.MapTask.run(MapTask.java:343)
?at org.apache.hadoop.mapred.YarnChild$2.run(YarnChild.java:163)
?at java.security.AccessController.doPrivileged(Native Method)
?at javax.security.auth.Subject.doAs(Subject.java:415)
?at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1671)
?at org.apache.hadoop.mapred.YarnChild.main(YarnChild.java:158)
Caused by: java.lang.reflect.InvocationTargetException
?at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
?at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57)
?at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
?at java.lang.reflect.Constructor.newInstance(Constructor.java:526)
?at org.apache.hadoop.hive.shims.HadoopShimsSecure$CombineFileRecordReader.initNextRecordReader(HadoopShimsSecure.java:251)
?... 11 more
Caused by: java.io.IOException: No LZO codec found, cannot run.
?at com.hadoop.mapred.DeprecatedLzoLineRecordReader.<init>(DeprecatedLzoLineRecordReader.java:53)
?at com.hadoop.mapred.DeprecatedLzoTextInputFormat.getRecordReader(DeprecatedLzoTextInputFormat.java:156)
?at org.apache.hadoop.hive.ql.io.CombineHiveRecordReader.<init>(CombineHiveRecordReader.java:66)
?... 16 more


FAILED: Execution Error, return code 2 from org.apache.hadoop.hive.ql.exec.mr.MapRedTask
MapReduce Jobs Launched:
Stage-Stage-1: Map: 1? Reduce: 1?? HDFS Read: 0 HDFS Write: 0 FAIL
Total MapReduce CPU Time Spent: 0 msec

解决方法:

检查hadoop集群是否添加了hadoop-lzo-*.jar,该jar包是否已配置到HADOOP_CLASSPATH里

如果配置进去了,并检查core-site.xml里是否配置了如下信息:

<property>
?<name>io.compression.codecs</name>
?<value>
??org.apache.hadoop.io.compress.GzipCodec,
??org.apache.hadoop.io.compress.DefaultCodec,
??org.apache.hadoop.io.compress.BZip2Codec,
??org.apache.hadoop.io.compress.SnappyCodec,
??com.hadoop.compression.lzo.LzoCodec,
??com.hadoop.compression.lzo.LzopCodec
?</value>
?<description>
??A comma-separated list of the compression codec classes
??that can be
??used for compression/decompression. In addition to any
??classes
??specified with this property (which take precedence), codec
??classes
??on the classpath are discovered using a Java ServiceLoader.
?</description>
</property>

<property>
?<name>io.compression.codec.lzo.class</name>
?<value>com.hadoop.compression.lzo.LzoCodec</value>
</property>

如果满足这两点,应该就可以了(注意:hive安装包的lib目录不用添加hadoop-lzo-*.jar)。

?

hive解析lzo文件失败,No LZO codec found, cannot run

原文:http://liuyq1991.iteye.com/blog/2258241

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!