java调用 Hbase报错
伪分布式hbase服务搭建,系统操作都很正常,也可以查询所有的表的列表,但是查询表的详情,调用的时候就会报错
java.net.connectexception: call to localhost/127.0.0.1:16020 failed on connection exception
从报错信息也能看出来,应该是master节点,查询表的名称应该是只读取了master信息,而表的具体信息就需要读取regionserver的信息了,master把regionserver的本地IP返回给远程java程序了,导致连接本地16020端口,这是肯定不对的
问题是这个问题,可是怎么解决呢?搜索无数资料,改了无数次hostname和防火墙配置,无效
最终查看hbase配置文件的时候,发现一个配置
<property>
<name>hbase.regionserver.hostname.disable.master.reversedns</name>
<value>true</value>
</property>
默认是false,改成true,重启,发现regionServer名称变成了hadoop001而不是localhost了,本地测试,创建表成功
这个配置的意思就是master不要解析regionServer的ip,直接返回,跟hdfs的配置一样,不过又换了个名字。。。