hbase中强制删除表

来源:互联网 发布:荣威rx5矩阵大灯 编辑:程序博客网 时间:2024/05/17 02:03

http://blog.sina.com.cn/s/blog_627b44450101jf6j.html
因为集群硬盘紧俏,绝对对原来的表加上COMPRESSION=>LZO属性。但是创建表,长时间没有反馈。决定drop掉这张表,但是始终drop失败。重启集群,hbase60010界面显示有regiontransaction。为创建失败的表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上的所有文件(路径根据实际情况而定):
[sql] viewplaincopy
  1. ./hadoop fs -rmr /hbase/TrojanInfo  
   2、删除该表在HBase系统表.META.中的记录:
       A、首先从.META.中查询出表TrojanInfo在.META.中的rowkey,这可以通过scan'.META.',然后手动筛选;
    B、然后删除该rowkey下的3个字段(假设查询出的rowkey为TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.)                  
[plain] viewplaincopy
  1. delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:server'  
  2. delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:serverstartcode'  
  3. delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:reg