今天遇到了一个恶心的问题:在HBase里面drop一个表,再重建,结果出错说这个表已经存在。再删,出错说这个表不存在。
在网上找,很多人说是因为.META.表里面残存了僵尸表的信息。但是在hbase shell中scan "hbase:meta"之后,没有发现任何问题。
后来找到了这篇文章,解决了问题:
原因是因为zookeeper里面也残留了僵尸表的信息。解决方法:
- hbase zkcli
- ls /hbase/table
- rmr /hbase/table/TABLE_NAME