首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 开源软件 >

用oozie执行pigAction与hiveAction的有关问题

2012-08-13 
用oozie执行pigAction与hiveAction的问题问题分析:oozie执行action时锁涉

用oozie执行pigAction与hiveAction的问题
===============================
问题分析:

oozie执行action时锁涉及到的jar包,都是用的oozie.libpath指定的sharelib路径中的jar包。

而pig和hive都依赖了antlr-x.x.x.jar。
最要命的是,他们两个还依赖的是不同版本的antlr。

我用的是pig-0.10.0和hive-0.8.1。
pig的jar包中,包含了antlr的runtime包,得先把这个删除。

然后,pig和hive的jar里面都没有antlr了。

pig兼容antlr-3.4-complete.jar.
hive兼容antlr-3.0.1.jar

所以,不能简单的把antlr的jar包放在sharelib路径中。


=============================
问题解决:
1,把pig的jar包中的antlr部分删除,前文讲过了。
2,sharelib中不要放antlr的jar包。
3,在hdfs中建立一个路径,我这里是/user/hadoop/Oozie/libext,把antlr-3.4-complete.jar和antlr-3.0.1.jar放到这个路径里。
4,A,在启动pigAction时,在action的定义中加入:
   <file>/user/hadoop/Oozie/libext/antlr-3.4-complete.jar</file>
   B,在启动hiveAction时,在action的定义中加入:
   <file>/user/hadoop/Oozie/libext/antlr-3.0.1.jar</file>
5,然后就没有然后了,pigAction和hiveAction都正常。



热点排行