HBase使用create创建表时报错ERROR: KeeperErrorCode = NoNode for /hbase/master

场景模拟

1. 正常情况

模拟ERROR: KeeperErrorCode = NoNode for /hbase/master错误场景。

正常情况下创建hbase表如下图所示。

2. 删除hbase集群的zk节点

进入zookeeper客户端。

shell 复制代码
zkCli.sh

删除hbase的zk节点。

zookeeper 复制代码
deleteall /hbase

退出zookeeper客户端。

zookeeper 复制代码
quit

3. 重启hbase集群

3.1 单独停止 master 和 regionserver

虚拟机Hadoop1执行stop-hbase.sh命令不能成功停止hbase集群,则在虚拟机Hadoop1执行如下命令单独停止master。

shell 复制代码
hbase-daemon.sh stop master

虚拟机Hadoop2和Hadoop3执行如下命令单独停止regionserver。

shell 复制代码
hbase-daemon.sh stop regionserver


3.2 启动hbase集群

虚拟机Hadoop1执行如下命令启动hbase集群。

shell 复制代码
start-hbase.sh

进入hbase客户端。

shell 复制代码
hbase shell

4. 再次创建表

再次创建表时,可以看到使用create创建表时报错ERROR: KeeperErrorCode = NoNode for /hbase/master。


原因分析

通过上面的情景模拟,我们可以看到报错的原因在于zookeeper中出现问题,可能是zookeeper中的/hbase/master被删除,或者是在hbase集群启动之后重新安装了zookeeper,导致zookeeper中的/hbase/master节点数据异常。


解决方案

1. 停止hbase对应服务进程

1.1 单独停止 master 和 regionserver

虚拟机Hadoop1执行如下命令单独停止master。

shell 复制代码
hbase-daemon.sh stop master

虚拟机Hadoop2和Hadoop3执行如下命令单独停止regionserver。

shell 复制代码
hbase-daemon.sh stop regionserver


2. 删除hdfs上hbase生成的数据目录

shell 复制代码
hdfs dfs -rm -r /hbase

3. 进入zookeeper客户端,删除对应hbase的节点

进入zookeeper客户端。

shell 复制代码
zkCli.sh

删除hbase的zk节点。

zookeeper 复制代码
deleteall /hbase

退出zookeeper客户端。

zookeeper 复制代码
quit

4. 删除hbase在Linux本地的临时数据目录

虚拟机Hadoop1执行如下命令删除hbase在Linux本地的临时数据目录。

shell 复制代码
rm -rf /export/data/hbase2.4.18

5. 重新启动hbase集群

虚拟机Hadoop1执行如下命令重新启动hbase集群。

shell 复制代码
start-hbase.sh

进入hbase客户端。

shell 复制代码
hbase shell

再次创建表,可以看到创建成功。

相关推荐
做梦敲代码16 分钟前
达梦数据库-读写分离集群部署
数据库·达梦数据库
小蜗牛慢慢爬行1 小时前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
hanbarger1 小时前
nosql,Redis,minio,elasticsearch
数据库·redis·nosql
微服务 spring cloud1 小时前
配置PostgreSQL用于集成测试的步骤
数据库·postgresql·集成测试
先睡1 小时前
MySQL的架构设计和设计模式
数据库·mysql·设计模式
弗罗里达老大爷1 小时前
Redis
数据库·redis·缓存
仰望大佬0072 小时前
Avalonia实例实战五:Carousel自动轮播图
数据库·microsoft·c#
学不透java不改名2 小时前
sqlalchemy连接dm8 get_columns BIGINT VARCHAR字段不显示
数据库
一只路过的猫咪2 小时前
thinkphp6使用MongoDB多个数据,聚合查询的坑
数据库·mongodb