访问IDE Eclipse中的hbase,java.net.UnknownHostException

时间:2013-11-06 13:01:45

标签: hadoop hbase

当我编写java代码来访问IDE Eclipse中的hbase时,总会显示消息“java.net.UnknownHostException”。但是hbase shell运行良好。   我在伪分发模式下在单个linux节点上安装hadoop和hbase。我的主机名是yzd。这是/ etc / hosts和hbase-site.xml:

/etc/hosts:
127.0.0.1 localhost yzd

hbase-site.xml:
      <property>
              <name>hbase.rootdir</name>
              <value>hdfs://localhost:9000/hbase</value>
      </property>
      <property>
              <name>hbase.cluster.distributed</name>
              <value>true</value>
      </property>
      <property>
              <name>dfs.replication</name>
              <value>1</value>
      </property>

Error message:
INFO [main] (HBaseRPC.java:117) - Using org.apache.hadoop.hbase.ipc.WritableRpcEngine for org.apache.hadoop.hbase.ipc.HMasterInterface
INFO [main] (HConnectionManager.java:596) - getMaster attempt 0 of 10 failed; retrying after sleep of 1000

java.net.UnknownHostException: unknown host: �  13846@yzdlocalhost
at org.apache.hadoop.hbase.ipc.HBaseClient$Connection.<init>(HBaseClient.java:224)
at org.apache.hadoop.hbase.ipc.HBaseClient.getConnection(HBaseClient.java:954)
at org.apache.hadoop.hbase.ipc.HBaseClient.call(HBaseClient.java:816)
at org.apache.hadoop.hbase.ipc.WritableRpcEngine$Invoker.invoke(WritableRpcEngine.java:141)
at com.sun.proxy.$Proxy4.getProtocolVersion(Unknown Source)
at org.apache.hadoop.hbase.ipc.WritableRpcEngine.getProxy(WritableRpcEngine.java:174)
at org.apache.hadoop.hbase.ipc.HBaseRPC.getProxy(HBaseRPC.java:295)
at org.apache.hadoop.hbase.ipc.HBaseRPC.getProxy(HBaseRPC.java:272)
at org.apache.hadoop.hbase.ipc.HBaseRPC.getProxy(HBaseRPC.java:324)
at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.getMaster(HConnectionManager.java:579)
at org.apache.hadoop.hbase.client.HBaseAdmin.<init>(HBaseAdmin.java:94)
at com.hbasebook.hush.schema.SchemaManager.process(SchemaManager.java:126)
at com.hbasebook.hush.HushMain.main(HushMain.java:57)

2 个答案:

答案 0 :(得分:0)

检查本地hbase的版本是否与您在pom中使用的版本匹配。这应该可以解决您的问题。我遇到了同样的问题,我在独立模式下使用hbase。我希望这会对你有所帮助。

答案 1 :(得分:0)

首先,yzd不是主机名,它的域名(你应该更喜欢FQDN)。现在这一行

java.net.UnknownHostException: unknown host: �  13846@yzdlocalhost

明确表示 13846 @ yzdlocalhost 主机不存在。现在你可以做以下事情:

  1. 在hbase-site.xml和core-site.xml中使用IP地址而不是主机名,然后检查
  2. 然后在etc / hosts文件中使用FQDN并使用制表符分隔值,现在可以用FQDN替换IP