KeeperErrorCode = NoNode for /hbase/meta-region-server

连接hbase报以下错:

Caused by: java.io.IOException: org.apache.zookeeper.KeeperException$NoNodeException: KeeperErrorCode = NoNode for /hbase/meta-region-server
	at org.apache.hadoop.hbase.client.ConnectionImplementation.get(ConnectionImplementation.java:2013)
	at org.apache.hadoop.hbase.client.ConnectionImplementation.locateMeta(ConnectionImplementation.java:789)
	at org.apache.hadoop.hbase.client.ConnectionImplementation.locateRegion(ConnectionImplementation.java:756)
	at org.apache.hadoop.hbase.client.ConnectionImplementation.locateRegion(ConnectionImplementation.java:745)
	at org.apache.hadoop.hbase.client.ConnectionImplementation.locateRegion(ConnectionImplementation.java:716)
	at org.apache.hadoop.hbase.client.ConnectionImplementation.getRegionLocation(ConnectionImplementation.java:594)
	at org.apache.hadoop.hbase.client.HRegionLocator.getRegionLocation(HRegionLocator.java:72)
	at org.apache.hadoop.hbase.client.RegionServerCallable.prepare(RegionServerCallable.java:223)
	at org.apache.hadoop.hbase.client.RpcRetryingCallerImpl.callWithRetries(RpcRetryingCallerImpl.java:105)
	... 23 more
Caused by: org.apache.zookeeper.KeeperException$NoNodeException: KeeperErrorCode = NoNode for /hbase/meta-region-server
	at org.apache.zookeeper.KeeperException.create(KeeperException.java:111)
	at org.apache.zookeeper.KeeperException.create(KeeperException.java:51)
	at org.apache.hadoop.hbase.zookeeper.ReadOnlyZKClient$ZKTask$1.exec(ReadOnlyZKClient.java:168)
	at org.apache.hadoop.hbase.zookeeper.ReadOnlyZKClient.run(ReadOnlyZKClient.java:323)
	at java.lang.Thread.run(Thread.java:745)

代码为:

val zk_quorum = PropertyUtil.getValueByKey("conf/dipc.properties", "zookeeper_hadoop_connection")
  val zk_port = PropertyUtil.getValueByKey("conf/dipc.properties", "zookeeper_hadoop_port")
  val hbase_parent = PropertyUtil.getValueByKey("conf/dipc.properties", "zookeeper_znode_parent")

  val hbaseConf = HBaseConfiguration.create()
  hbaseConf.set("hbase.zookeeper.quorum", zk_quorum) //设置zooKeeper集群地址,也可以通过将hbase-site.xml导入classpath,但是建议在程序里这样设置
  hbaseConf.set("hbase.zookeeper.property.clientPort", zk_port) //设置zookeeper连接端口,默认2181
  hbaseConf.set("zookeeper.znode.parent",hbase_parent)
  hbaseConf.set(TableInputFormat.INPUT_TABLE, tableName)

  private val conn: Connection = ConnectionFactory.createConnection(hbaseConf)
  private val admin: Admin = conn.getAdmin

dipc.properties

#hadoop ZK客户端连接信息
zookeeper_hadoop_connection=zk1:2181,zk2:2181,zk3:2181
zookeeper_hadoop_port=2181
 
#hbase相关配置
zookeeper_znode_parent=/hbase

解决方案:zookeeper.znode.parent的值不是/hbase ,而是/hbase-unsecure,不同的环境,此默认值不一样,CDH是/hbase,HDP是/hbase-unsecure,我们用的是HDP,修改为hbase即可,或者更改代码为/hbase-unsecure

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值