设为首页 收藏本站
查看: 2155|回复: 0

[经验分享] Hive ClassNotFoundException: org.apache.hadoop.hive.contrib.serde2.RegexSerDe

[复制链接]

尚未签到

发表于 2016-12-10 11:29:31 | 显示全部楼层 |阅读模式
在Hive的测试中,发现使用正则表达式的字段分隔方式时,总是进行不下去,创建表的语句如下:
create table mylog2(time string,clause string) row format serde 'org.apache.hadoop.hive.contrib.serde2.RegexSerDe' with serdeproperties (
"input.regex" = "(\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2},\\d{3}) - (.*) -(.*)"
);

  通过查看Tracking URL,发现抛出类找不到的异常,类

org.apache.hadoop.hive.contrib.serde2.RegexSerDe没有找到。  

  解决方法:
  将下面的配置语句,加在配置文件: $HIVE_INSTALL/conf/hive-site.xml中,value中hive-contrib-*.jar的路径为你机器上实际的放置,在$HIVE_INSTALL/lib目录下寻找。

  <property>

<name>hive.aux.jars.path</name>

<value>file:///home/develop/hive-0.8.0/lib/hive-contrib-0.8.0.jar</value>

<description>Added by tiger.zeng on 20120202.These JAR file are available to all users for all jobs</description>

</property>

  退出hive shell, 重新启动hive shell, 可运行正常。

运行结果如下:  hive> select time,clause from mylog2;

Total MapReduce jobs = 1

Launching Job 1 out of 1

Number of reduce tasks is set to 0 since there's no reduce operator

Starting Job = job_201202021642_0003, Tracking URL = http://hdp0:50030/jobdetails.jsp?jobid=job_201202021642_0003

Kill Command = /home/hadoop/hadoop-0.20.203.0/bin/hadoop job -Dmapred.job.tracker=hdp0:9001 -kill job_201202021642_0003

Hadoop job information for Stage-1: number of mappers: 1; number of reducers: 0

2012-02-02 16:58:43,327 Stage-1 map = 0%, reduce = 0%

2012-02-02 16:58:49,375 Stage-1 map = 100%, reduce = 0%

2012-02-02 16:58:55,437 Stage-1 map = 100%, reduce = 100%

Ended Job = job_201202021642_0003

MapReduce Jobs Launched:

Job 0: Map: 1 HDFS Read: 1286 HDFS Write: 564 SUCESS

Total MapReduce CPU Time Spent: 0 msec

OK

NULL NULL

NULL NULL

NULL NULL

NULL NULL

2012-01-17 00:14:19,301 org.apache.hadoop.conf.Configuration -0 [main] DEBUG org.apache.hadoop.conf.Configuration

NULL NULL

NULL NULL

NULL NULL

NULL NULL

NULL NULL

2012-01-17 00:14:19,314 org.apache.hadoop.util.NativeCodeLoader -13 [main] DEBUG org.apache.hadoop.util.NativeCodeLoader

2012-01-17 00:14:19,314 org.apache.hadoop.util.NativeCodeLoader -13 [main] INFO org.apache.hadoop.util.NativeCodeLoader

2012-01-17 00:14:19,316 org.apache.hadoop.io.compress.zlib.ZlibFactory -15 [main] INFO org.apache.hadoop.io.compress.zlib.ZlibFactory

NULL NULL

Time taken: 21.28 seconds

hive>



  参考:
  



Jasper Knulst 13020438802011年04月06日 星期三 06时51分20秒





    • Link Here
    • Print view




Hi(ve),
I created a table like this;
create table testtable (veld1 STRING,veld2 STRING,veld3 STRING) ROW FORMAT
SERDE 'org.apache.hadoop.hive.contrib.serde2.RegexSerDe'
> WITH SERDEPROPERTIES ("input.regex" =
"([a-z]{4}[0-9])þ([a-z]{4}[0-9])þ([a-z]{4}[0-9])") STORED AS TEXTFILE;

The table is OK, select * from testtable shows the contents of the
underlying HDFS file.
However when I invoke a MR job by select veld2 from testtable, the MR job
starts but I get mapper errors saying:
"Caused by: org.apache.hadoop.hive.ql.metadata.HiveException:
java.lang.ClassNotFoundException:
org.apache.hadoop.hive.contrib.serde2.RegexSerDe"
I already copied the hive serde jar (in my case hive-serde-0.7.0-CDH3B4.jar)
to $HADOOP_HOME/lib and restarted jobtracker/tasktrackers but that doesn't
help.
Cheers JasperShow footer--
Kind Regards \ Met Vriendelijke Groet,


Jasper Knulst
BI Consultant


VLC Den Haag
Gildeweg 5B
2632 BD  Nootdorp

M: +31 (0)6 19 66 75 11
T: +31 (0)15 764 07 50



Loren Siebert 13020443192011年04月06日 星期三 06时58分39秒





    • Link Here
    • Print view






You need to tell Hive about the JAR. This is how I do it in hive-site.xml:
<property>
<name>hive.aux.jars.path</name>
<value>file:///usr/lib/hive/lib/hive-contrib-0.7.0-CDH3B4.jar</value>
<description>These JAR file are available to all users for all jobs</description>
</property>Show quoted text

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-312356-1-1.html 上篇帖子: 用eclipse编译hadoop例子要做的修改 下篇帖子: [Hadoop源码解读](六)MapReduce篇之MapTask类
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表