tableNotEnabledException
http://stackoverflow.com/questions/19561048/how-to-properly-purge-hbase-meta-table-from-rows-without-region-info
|
I had a similar issue before. The problem was because Zookeeper was holding the table. So I deleted the table manually by following the below steps
- Enter into hbase zookeper client mode using 'hbase zkcli' command
- Delete the table using the command 'delete /hbase/table/x'
|
----------------------------------------------------------------------------------------------------------------------------------------------------------------
因为集群硬盘紧俏,绝对对原来的表加上COMPRESSION=>LZO属性。但是创建表,长时间没有反馈。决定drop掉这张表,但是始终drop失败。重启集群,hbase 60010界面显示有region transaction。为创建失败的表region,在PENDING_OPEN和CLOSED之间跳。describe 表失败, enable表失败,disable表失败,从60010界面查看表失败。很蛋疼。
后决定强制删除当前表。google了一下,找到这篇文章,文章大部分都是对的,但是最后一步存在问题.原文中命令为:
delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:server'
当时就觉得有有问题,没有涉及.META.表,如何更新META信息?
尝试两次删除后是始终报错,确定应该是有问题,为了以防万一,google一下更新META信息的操作,将命令改为
delete '.META.','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:server'
命令成功执行。
重启集群后,transction仍然存在,分析应该是meta表没有更新的问题,对meta表做一次major_compact,重启集群,成功。不再有报错。
下面是对原文的拷贝:
强制删除表:
1、强制删除该表在hdfs上的所有文件(路径根据实际情况而定):
- ./hadoop fs -rmr /hbase/TrojanInfo
2、删除该表在HBase系统表.META.中的记录:
A、首先从.META.中查询出表 TrojanInfo在.META.中的rowkey,这可以通过
scan '.META.'
,然后手动筛选;
B、然后删除该rowkey下的3个字段(假设查询出的rowkey为TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af95
82f29bd8.)
- delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:server'
- delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:serverstartcode'
- delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:reg
-------------------------------------------------------------------------------------
delete'.META.','O_P_NEW,,1427283540027.f878300eec43ae3006b1b718b0f234a7.','info:server'
delete'.META.','O_P_NEW,\x00\x00\x00\x02,1427283540027.d2d09b1a446fb8292a4e2795f41d15bb.','info:serverstartcode'
delete'.META.','O_P_NEW,\xFA\xE1G\xB0,1427283540033.be7399d4ed3dc07087b450699082c405.','info:regioninfo'
保存到一个a.sh里 用hbase shell a.sh
flush .META.'
major_compact '.META.'
然后zookeeper内干掉 这个表的信息 重启,,,,hbase 重启。。。
--------------------------------------------------------------------
hbase hbck -fixMeta > /tmp/hbck1.log 2>&1
--------------------
http://stackoverflow.com/questions/19561048/how-to-properly-purge-hbase-meta-table-from-rows-without-region-info
--------------------
|
Ended with offline repair tool:
hbase org.apache.hadoop.hbase.util.hbck.OfflineMetaRepair
It fixed all my problems for now but I'd like to see other options.
|