当我以嵌入式方式启动 HBase 时,它可以完美运行。
我在 Ubuntu 12.04 上,我通过下载 tar.gz 并在 opt 目录上解压缩安装了 hbase 0.90.5。
HBase 已正确启动,在日志中没有崩溃也没有异常,因此似乎 HBase 已正确安装。hbase-site.xml 很简单:
<configuration>
<property>
<name>hbase.zookeeper.quorum</name>
<value>localhost</value>
</property>
<property>
<name>hbase.zookeeper.property.clientPort</name>
<value>2181</value>
</property>
然后我的 etc/hosts 文件就更简单了:
127.0.0.1 localhost
127.0.0.1 alex-desktop
请注意,我已经阅读了有关从此文件中删除主机名的信息,但是这样做只会在启动 hbase 时导致错误。所以我决定离开这里。
最后是我的 Java 代码:
Configuration config = HBaseConfiguration.create();
config.clear();
config.set("hbase.zookeeper.quorum", "localhost");
config.set("hbase.zookeeper.property.clientPort","2181");
config.set("hbase.master", "localhost:60000");
我在日志中得到异常:
2/10/25 21:41:59 INFO zookeeper.ClientCnxn: Session establishment complete on server localhost/127.0.0.1:2181, sessionid = 0x13a996f3e1d000b, negotiated timeout = 40000
12/10/25 21:41:59 INFO client.HConnectionManager$HConnectionImplementation: getMaster attempt 0 of 1 failed; no more retrying.
java.io.IOException: Call to localhost/127.0.0.1:60001 failed on local exception: java.io.EOFException at org.apache.hadoop.hbase.ipc.HBaseClient.wrapException(HBaseClient.java:954)
at org.apache.hadoop.hbase.ipc.HBaseClient.call(HBaseClient.java:923)
at org.apache.hadoop.hbase.ipc.WritableRpcEngine$Invoker.invoke(WritableRpcEngine.java:150)
at $Proxy6.getProtocolVersion(Unknown Source)
at org.apache.hadoop.hbase.ipc.WritableRpcEngine.getProxy(WritableRpcEngine.java:183)
请注意,端口 60001 会发生变化,有时是此端口,但也可以是其他任何端口,例如 46666。
我也尝试过导出导出HBASE_MANAGES_ZK=true
,但没有帮助。我不知道接下来我能做什么,因为我不知道这个随机端口是什么。
有谁知道发生了什么?
非常感谢您提前。