干掉HBase中的僵尸表

今天遇到了一个恶心的问题:在HBase里面drop一个表,再重建,结果出错说这个表已经存在。再删,出错说这个表不存在。

在网上找,很多人说是因为.META.表里面残存了僵尸表的信息。但是在hbase shell中scan ".META."之后,没有发现任何问题。

后来找到了这篇文章,解决了问题:

http://arnon.me/2013/01/killing-hbase-zombie-table/

原因是因为zookeeper里面也残留了僵尸表的信息。解决方法:

hbase zkcli
进入zookeeper命令行。然后

ls /hbase/table
看到僵尸表赫然在列。把它干掉:

rmr /hbase/table/TABLE_NAME

另外,我发现在/hbase下面还有个table94,貌似是hbase的版本号的样子,里面也有表名,而且僵尸表也在里面,一并干掉。

最后需要重启一下hbase和zookeeper。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值