欢迎投稿

今日深度:

HBase(06)——HBase寻址机制,

HBase(06)——HBase寻址机制,


寻址流程

假设我们要从Table2里面查询一条RowKey是rk0001的数据。那么我们应该遵循以下步骤:

系统如何找到某个row key (或者某个 row key range)所在的region
bigtable 使用三层类似B+树的结构来保存region位置。
第一层: 保存zookeeper里面的文件,它持有root region的位置。
第二层:root region是.META.表的第一个region其中保存了.META.表其它region的位置。通过root region,我们就可以访问.META.表的数据。
第三层: .META.表它是一个特殊的表,保存了hbase中所有数据表的region 位置信息。

说明:
(1) root region永远不会被split,保证了最需要三次跳转,就能定位到任意region 。
(2).META.表每行保存一个region的位置信息,row key 采用表名+表的最后一行编码而成。
(3) 为了加快访问,.META.表的全部region都保存在内存中。
(4) client会将查询过的位置信息保存缓存起来,缓存不会主动失效,因此如果client上的缓存全部失效,则需要进行最多6次网络来回,才能定位到正确的region(其中三次用来发现缓存失效,另外三次用来获取位置信息)。

Region定位流程

a) 寻找RegionServer
ZooKeeper–> -ROOT-(单Region)–> .META.–> 用户表

b) -ROOT-表
表包含.META.表所在的region列表,该表只会有一个Region;
Zookeeper中记录了-ROOT-表的location。

也称namespace。
c) .META.表
表包含所有的用户空间region列表,以及RegionServer的服务器地址

www.htsjk.Com true http://www.htsjk.com/hbase/38483.html NewsArticle HBase(06)——HBase寻址机制, 寻址流程 假设我们要从Table2里面查询一条RowKey是rk0001的数据。那么我们应该遵循以下步骤: 系统如何找到某个row key (或者某个 row key range)所在的region bi...
相关文章
    暂无相关文章
评论暂时关闭