zoukankan      html  css  js  c++  java
  • Hbase region查找过程

    HBase的table是该region切分的,client操作一个row的时候,如何知道这个row对应的region是在哪台Region server上呢?这里有个region location过程。主要涉及到2张系统表,-ROOT-,.META.。其结构见图

     

    在zookeeper的/hbase/root-region-server节点中存着-ROOT-表所在的Region Server地址。

    -ROOT-表的一个row代表着META的一个region信息,其key的结构是META表名,META表Region的startkey,RegionId。其value的主要保存regioninfo和server信息。ROOT表不能split

    .META.表的一个row代表着用户表的一个region信息,其key的结构是其实就是用户表的regionName,用户表名,startKey,RegionId。其value同样保存着regioninfo和server信息。META表可以split,但是一个region默认有128M,可以存上亿个用户表的region信息,所以一般不会split。

    其查找过程如下:

    1.通过zk getData拿-ROOT-表的location

    2.RPC -ROOT-表的rs,getClosestRowBefore,拿row对应的meta表的region location

    3.RPC .META.表的某一个region,拿该row在真实table所在的region location

    4.RPC对应region

  • 相关阅读:
    js关闭当前页面(窗口)的几种方式总结
    Servlet 文件上传
    Servlet Cookie 处理
    Servlet Session 跟踪
    Servlet 异常处理
    Servlet 编写过滤器
    Servlet HTTP 状态码
    Servlet 服务器 HTTP 响应
    Servlet 客户端 HTTP 请求
    Servlet 表单数据
  • 原文地址:https://www.cnblogs.com/haihua85/p/9041321.html
Copyright © 2011-2022 走看看