HBase源代码调试(5)

When create a new HTable("testwy")

and 'testwy' is not exists in current .META.


org.apache.hadoop.hbase.TableNotFoundException: Cannot find row in .META. for table: testwy, row=testwy,,99999999999999

    at org.apache.hadoop.hbase.client.MetaScanner.metaScan(MetaScanner.java:164)
    at org.apache.hadoop.hbase.client.MetaScanner.access$1(MetaScanner.java:143)
    at org.apache.hadoop.hbase.client.MetaScanner$1.connect(MetaScanner.java:133)
    at org.apache.hadoop.hbase.client.MetaScanner$1.connect(MetaScanner.java:1)
    at org.apache.hadoop.hbase.client.HConnectionManager.execute(HConnectionManager.java:360)
    at org.apache.hadoop.hbase.client.MetaScanner.metaScan(MetaScanner.java:130)
    at org.apache.hadoop.hbase.client.MetaScanner.metaScan(MetaScanner.java:105)
    at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.prefetchRegionCache(HConnectionManager.java:922)
    at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.locateRegionInMeta(HConnectionManager.java:977)
    at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.locateRegion(HConnectionManager.java:864)
    at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionImplementation.locateRegion(HConnectionManager.java:821)
    at org.apache.hadoop.hbase.client.HTable.finishSetup(HTable.java:234)
    at org.apache.hadoop.hbase.client.HTable.<init>(HTable.java:174)
    at org.apache.hadoop.hbase.client.HTable.<init>(HTable.java:133)

    at PutExample.main(PutExample.java:18)


In HConnectionManager.java

public static <T> T execute(HConnectable<T> connectable) throws IOException {
    if (connectable == null || connectable.conf == null) {
      return null;
    }
    Configuration conf = connectable.conf;
    HConnection connection = HConnectionManager.getConnection(conf);
    boolean connectSucceeded = false;
    try {
      T returnValue = connectable.connect(connection);
      connectSucceeded = true;
      return returnValue;
    } finally {
      try {
        connection.close();
      } catch (Exception e) {
        if (connectSucceeded) {
          throw new IOException("The connection to " + connection
              + " could not be deleted.", e);
        }
      }
    }
  }

In MetaScanner.java

 public static void metaScan(Configuration configuration,
      final MetaScannerVisitor visitor, final byte[] tableName,
      final byte[] row, final int rowLimit, final byte[] metaTableName)
      throws IOException {
    try {
      HConnectionManager.execute(new HConnectable<Void>(configuration) {
        @Override
        public Void connect(HConnection connection) throws IOException {
          metaScan(conf, connection, visitor, tableName, row, rowLimit,
              metaTableName);
          return null;
        }
      });
    } finally {
      visitor.close();
    }
  }

-------------------------------------------------------------------------------------------------------

下面的例子以Debug Configurations中Main Class 为org.apache.hadoop.hbase.io.hfile.HFile 

arguments 为 -f  /home/xxxxx/data/wang/..../cf/...  (data file path)  -v -m -p 


一个HFile文件(data file)的二进制表示


文件中黑色反选的部分就是HFile的所谓Trailer部分

TRABLK"$ 是个hardcode的magic

D3 ,  69等是一些offset, 通过代码in function FixedFileTrailer.deserialize,

fileInfoOffset =inputStream.readLong();

loadOnOpenDataOffset =  inputStream.readLong()等代码读出



该文件靠前的部门有两个IDXROOT2  tag,一个是Data index,另一个是Meta index

接下来是fileInfo


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值