删除meta表

tableNotEnabledException
http://stackoverflow.com/questions/19561048/how-to-properly-purge-hbase-meta-table-from-rows-without-region-info

9
down vote accepted

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

  1. Enter into hbase zookeper client mode using 'hbase zkcli' command
  2. 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上的所有文件(路径根据实际情况而定):
[sql]  view plain copy
  1. ./hadoop fs -rmr /hbase/TrojanInfo  
      2、删除该表在HBase系统表.META.中的记录:
              A、首先从.META.中查询出表 TrojanInfo在.META.中的rowkey,这可以通过 scan '.META.' ,然后手动筛选;
        B、然后删除该rowkey下的3个字段(假设查询出的rowkey为TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af95 82f29bd8.)                                   
[plain]  view plain copy
  1. delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:server'  
  2. delete 'TrojanInfo','TrojanInfo,,1361433390076.2636b5a2b3d3d08f23d2af9582f29bd8.','info:serverstartcode'  
  3. 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
--------------------

up vote 0 down vote accepted

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.





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值