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之前。