bulkload出现了KeeperException问题

昨天使用hbase的bulk load的时候,出现了以下异常:

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/zookeeper/KeeperException

atjava.lang.Class.getDeclaredMethods0(NativeMethod)

atjava.lang.Class.privateGetDeclaredMethods(Class.java:2427)

atjava.lang.Class.getMethod0(Class.java:2670)

        at java.lang.Class.getMethod(Class.java:1603

这个异常也是比较常见的,是hadoop执行bulk load的时候找不到zookeeper的jar包,需要将zookeeper的jar放在$HADOOP_HOME/lib下。

可是zookeeper的jar包是在$HADOOP_HOME/lib下,并且前天在调用bulk load命令的时候,是没有任何问题的。

在服务器上执行hadoop命令的时候,发现调用的hadoop命令不是当前用户下安装的hadoop,这就是问题所在了,于是指定当前用户目录下的$HADOOP_HOME/bin/hadoop执行bulk load程序,一切正常。

呵呵,原来是环境变量改变了。

补充:

是环境变量的问题影响的,由于前两天一个同事在另一个用户下使用cloudera的安装程序安装了hadoop,将安装的hadoop命令放在/usr/bin下了,检查了一下自己用户下的环境变量,看到PATH中/usr/bin在$HADOOP_HOME之前,这样执行hadoop命令,肯定是先找到/usr/bin下的hadoop了,所以需要将当前用户下的环境变量修改一下,将$HADOOP_HOME提到/usr/bin之前。

相关推荐