===============================
问题分析:
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都正常。
问题分析:
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都正常。