因为集群硬盘紧俏,绝对对原来的表加上COMPRESSION=>LZO属性。但是创建表,长时间没有反馈。决定drop掉这张表,但是始终drop失败。重启集群,hbase 60010界面显示有region transaction。为创建失败的表region,在PENDING_OPEN和CLOSED之间跳。describe 表失败, enable表失败,disable表失败,从60010界面查看表失败。很蛋疼。
后决定强制删除当前表。google了一下,找到这篇文章,文章大部分都是对的,但是最后一步存在问题.原文中命令为:
delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af95 82f29bd8.','info:server'
当时就觉得有有问题,没有涉及.META.表,如何更新META信息?
尝试两次删除后是始终报错,确定应该是有问题,为了以防万一,google一下更新META信息的操作,将命令改为
delete '.META.','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af95 82f29bd8.','info:server'
命令成功执行。
重启集群后,transction仍然存在,分析应该是meta表没有更新的问题,对meta表做一次major_compact,重启集群,成功。不再有报错。
下面是对原文的拷贝:
强制删除表:
- ./hadoop
fs -rmr /hbase/TrojanInfo
- delete
'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af95 82f29bd8.','info:server' - delete
'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af95 82f29bd8.','info:serverstartcode' - delete
'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af95 82f29bd8.','info:reg