HBase读数据和写数据流程

Hbase架构图镇楼:

HBase读数据的流程:

  1. HRegionServer保存着meta表以及表数据,要访问表数据,首先Client先去访问zookeeper,从zookeeper里面获取meta表所在的位置信息,即找到这个meta表在哪个HRegionServer上保存着。
  2. 接着Client通过刚才获取到的HRegionServer的IP来访问Meta表所在的HRegionServer,从而读取到Meta,进而获取到Meta表中存放的元数据。
  3. Client通过元数据中存储的信息,访问对应的HRegionServer,然后扫描所在HRegionServer的Memstore和Storefile来查询数据。
  4. 最后HRegionServer把查询到的数据响应给Client。

HBase写数据的流程:

  1. Client首先访问zookeeper,找到Meta表,并获取Meta表中元数据。确定当前将要写入的数据所对应的HRegion和HRegionServer服务器。
  2. Client向该HRegionServer服务器发起写入数据请求,然后HRegionServer收到请求并响应。然后先把数据写入到HLog,以防止数据丢失。
  3. 最后将数据写入到Memstore。

其实如果HLog和Memstore均写入成功,则这条记录便算写入成功了。Memstore会在满足以下情况的前提下将数据一次性flush到Storefile中:

  1. Memstore写满(128M)
  2. HLog中的记录数达到默认值32
  3. Memstore占用内存达到总内存的40%

在HBase中需要注意下面三个临界点合并或拆分文件:

  1. 第一个就是上面的memstore的flush机制,如果Memstore达到阈值,会把Memstore中的数据flush到Storefile中。
  2. 当Storefile越来越多,会触发Compact合并操作,把过多的Storefile合并成一个大的Storefile。
  3. 当Storefile越来越大,Region也会越来越大,达到阈值后,会触发split操作,将Region一分为二。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

5t李

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值