我有一个带有Oozie 4.2.0,Hadoop 2.7,Hive 1.1.2和Java 1.8的伪分布式集群。在我使用组件构建Oozie发行版后,我试图复制"共享库"到HDFS。当我运行命令它给我以下错误。我认为缺少一个JAR文件(或者说是这样)。
我不是JAVA人,也不知道这个错误。但是,我认为如果我已经使用所有必需的JAR文件成功构建了Oozie,则不应该出现此错误。我浏览了所有其他类似的Oozie问题与JNI错误,但我找不到解决这个问题的可靠答案。请问有人能在这方面帮助我吗?
oozie-setup.sh sharelib create -fs hdfs://localhost:9000
Error: A JNI error has occurred, please check your installation and try
again
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache
/hadoop/conf/Configuration
at java.lang.Class.getDeclaredMethods0(Native Method)
at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)
at java.lang.Class.privateGetMethodRecursive(Class.java:3048)
at java.lang.Class.getMethod0(Class.java:3018)
at java.lang.Class.getMethod(Class.java:1784)
at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544)
at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526)
Caused by: java.lang.ClassNotFoundException:
org.apache.hadoop.conf.Configuration
at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 7 more
答案 0 :(得分:1)
我自己找到了解决方案,
第1步:将$ HADOOP_INSTALL / share / common / *。jar复制到$ OOZIE_INSTALL / libext
第2步:重建.WAR文件
第3步:重新运行oozie