`

[转载]HBase Region 分配 探索 分区

阅读更多

 HBase 的 cluster 中, Region 是如何分配这个问题,困扰了我很久,经过代码分析和调试,得出了一些见解,缺点和错误请大家批评指正。

 

参与 Region 分配的重要对象

在 Region 分配过程中,起着重要作用有如下一些对象。

 

  • HMaster— 是 HBase 中的 Master server ,仅有一个。
  • HRegionServer--- 负责多个 HRegion 使之能向 client 端提供服务,在 HBase cluster 中存在多个HRegionServer 。

 

 

  • ServerManager--- 负责管理 Region server 信息,比如每个 Region server 的 HServerInfo( 这个对象包含HServerAddress 和 startCode), 已 load Region 个数,死亡的 Region server 列表

   

  •   RegionManager --- 负责将 region 分配到 region server 的具体工作,还有监视 root 和 meta 这 2 个特殊 region的状态。
  • RootScanner --- 定期扫描 root region ,以发现没有分配的 meta region 。
  • MetaScanner--- 定期扫描 meta region, 以发现没有分配的 user region 。

 

这些对象的关系如图所示:

 

  

Region 分配过程

 

  • Root region 的分配

 

HMaster 起动时,首先会通过 RegionManager 把 rootRegionLocation (里面包含 HServerAddress )的值置为null ,然后把 root region 从待处理 region 列表中移除(如果有的话),然后重新将其放入待处理 region 列表(regionsInTransition ),并将其状态设置为 UNASSIGNED( 未分配 ).

 

当一个 Region server 启动完成时,它会调用 reportForDuty 函数向 HMaster 报告它的启动,报告当然是通过HMasterRegionInterface 的 regionServerStartup 方法。然后 HMaster 会把 Region server 的报告转交给ServerManager 的 regionServerStartup 方法处理。 ServerManager 会将这个新的 RegionServer 加入 region server列表并且把它的 server load 设为空闲的。

 

RegionServer 会定期发送报告给 HMaster ,请求 HMaster 进一步的指示。发送报告是通过HMasterRegionInterface 的 regionServerReport 方法。 HMaster 接到报告后,移交报告给 ServerManager 的regionServerReport 方法处理。 ServerManager 会查询

regionServer 的状态,得到一个 HServerInfo 对像,然后检查 RegionServer 是否为正常的。如果为正常的话,ServerManager 会查询 regionserver 的负载( HServerLoad ),更新一个 loadToServers 的 map 。然后进入ServerManager 的 processMsgs 函数处理。

 

ServerManager 会检查该 regionServer 的已经打开的 region 的数目,如果打开的 region 数目少于一个固定的值(对应配置文件中的 hbase.regions.nobalancing.count ),然后就会调用 RegionManager 的 assignRegions 方法。

 

RegionManager 会向 ServerManager 查询,现在已启动的 RegionServer 有几个,如果只有一个的话,会做特别处理。

 

然后 RegionManager 调用自己的 regionsAwaitingAssignment 方法去取得等待分配的 region 集合。它先会特别考虑 root region ,如果它查到 root region 尚未被分配,它会马上返回只包含 root region 的集合。

 

如果没有任何 region 未分配的话而且并未处在安全模式, RegionManager 会让 loadBalancer 执行负载均衡的动作(就是可能把该 regionserver 负责的 region 分一点出去)。 反之如果有待分配的 region ,serverManager 会调用自己的 assignRegionsToMultipleServers

方法。

 

在 assignRegionsToMultipleServers 中,参数 regionsToAssign 是所有待分配的 region 集合,因为存在多个regionServer, 所以 regionManager 会考虑到多个 regionServer 的负载。 regionManager 会先调用regionsToGiveOtherServers 方法,求出其他 regionServer (比如相对负载较轻的)应该承载的 region 数目,那么当前 regionServer 可能承载的 region 个数就是待分配的 region 总数目减去其他 regionServer 应该承载的region 数目,这个数量我们暂称之为 N 。如果 N<=0 并且 Meta Region 如果已被分配的话,该 regionServer 会被略过,不会被要求承载 region 。因为比当前 regionServer 的负载轻的 regionServer 个数超过了待分配的region 个数,轮不到当前的 regionServer 。

 

看起来快水落石出了,但是剩下事情还有点复杂。 regionManager 还会调用 computeNextHeaviestLoad 方法,算出 cluster 中有多少 regionServer 超过当前的 regionServer ,这个数目我们暂称之为 NS ,同时该方法会抓出负载最重的 server 的负载。

 

接着 regionManager 会求出当前 regionServer 负责的 region 数目和负载最重的 regionServer 负责的 region 数目之间的差值。如果这个差值大于 N ,那么 N 个 region 将全部会交由当前 regionServer 负责。反之这个差值小于N,如果 NS 大于零,当前 regionServer 要被分配的 region 数量为 (int)Math.ceil(1.0*N/1.0*NS), 如果 NS 等于零,那么当前 regionServer 要被分配 region 的数量为 (int)Math.ceil(1.0*N/1.0*regionServer 总数 ) 。

 

 

然后 root region 就会被分配到该 RegionServer 上。

 

这里特别要提下:如果有多个 region serve 存在, HBase 不会把 root region 和 meta region 分配到一个RegionServer 上。

 

 

  • Meta region 的分配

 

一旦 root region 被分配完成, RootScanner 线程将被唤醒。然后它会 scan root region 。

 

在 scan 过程中,碰到每个 meta region 条目,它会调用 checkAssigned 函数检查,改 meta region 是否被分配,如果没有的话, regionManager 将会记录之,把该 region 加入待分配的 region 列表中。

 

一旦有 RegionServer 定期报告来了, meta region 会像 root region 一样的方式被分配。

 

 

  • User region 的分配

 

一旦 meta region 被分配完成, MetaScanner 将被唤醒,然后它会 scan  meta region 。

 

在 scan 过程中,碰到每个 user region 条目,它会调用 checkAssigned 函数检查,该 user region 是否被分配,如果没有的话, regionManager 将会记录之,把该 region 加入待分配的 region 列表中。

 

一旦有 RegionServer 定期报告来了, user region 会被分配。

分享到:
评论

相关推荐

    HBase的预分区

    这个region的rowkey是没有边界的,即没有start key和end key,在数据写入时,所有数据都会写入这个默认的region,随着数据量的不断增加,region的size越来越大时,大到一定的阀值,hbase认为再往这个region里塞数据...

    Hbase性能测试详细设计文档及用例q

    默认情况下,在创建HBase表的时候会自动创建一个region分区,当导入数据的时候,所有的HBase客户端都向这一个region写数据,直到这个region足够大了才进行切分。 一种可以加快批量写入速度的方法是通过预先创建一些...

    HBase内核及能力.pdf

    HBase的特性与生态:自动分区、LSM Tree、存储计算分离、HBase生态;全新的HBase2.0版本新功能:小对象存储MOB、读写链路Off-heap 、Region Replica 、In Memory Compaction 、Assignment MangerV2 、其他;HBase未来...

    HBaseRowkey的散列与预分区设计

    HBase中,表会被划分为1...n个Region,被托管在RegionServer中。Region二个重要的属性:StartKey与EndKey表示这个Region维护的rowKey范围,当我们要读/写数据时,如果rowKey落在某个start-endkey范围内,那么就会定位...

    hbase-manager安装包,已编译

    HBase表管理:表创建、预分区建表(内置三种预分区方案)、表删除、表信息更改、表清空 列簇管理:列簇新增、删除、属性修改 标签管理:HBase表的标签管理 数据管理:HBase表数据的查询、新增、删除。 多集群...

    关于hbase性能调优文档.docx

    默认情况下,在创建HBase表的时候会自动创建一个region分区,当导入数据的时候,所有的HBase客户端都向这一个region写数据,直到这个region足够大了才进行切分。一种可以加快批量写入速度的方法是通过预先创建一些空...

    HBase主要运行机制(物理存储和逻辑架构)

    因此,当一张表的行太多的时候,HBase就会根据行键的值对表中的行进行分区,每个行区间构成一个“分区(Region)”,包含了位于某个值域区间内的所有数据,如图 1所示。 图1HBase的Region存储模式图Region是按大小...

    通俗易懂的Hbase升级版教程(含配套资料)

    主要讲述了HBase详细的架构原理及特点、HBase内部各个角色的详细介绍、安装配置、HBase的Shell操作、新旧版本的读写数据详细流程、HBase的API操作、使用MapReduce以及Hive对HBase数据分析、Rowkey设计、预分区设计、...

Global site tag (gtag.js) - Google Analytics