2

当我以嵌入式方式启动 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,但没有帮助。我不知道接下来我能做什么,因为我不知道这个随机端口是什么。

有谁知道发生了什么?

非常感谢您提前。

4

1 回答 1

1

确保您same在客户端代码中使用 HBase 版本,就像在集群中一样。一般情况下EOFException会出现版本不匹配的情况。

于 2012-11-01T22:59:25.193 回答