用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都正常。



猜你喜欢

转载自taoo.iteye.com/blog/1559421