Hbase缓存读写优化

Hbase二级缓存
摘要由CSDN通过智能技术生成

缓存(BlockCache)

为了提高Hbase集群的读写性能,官方团队设计了两种缓存策略,这里说的缓存就是Block Cache。关于BlockCache官方提供了两种策略,堆内(on-heap)缓存LruBlockCache和BucketCache,其中BucketCache通常使用堆外(off-heap)内存。通常LruBlockCache被称为L1缓存,默认是开启的,建议不要关闭;BucketCache被称为L2缓存,开启L2缓存需要配置相关参数,例如hbase.bucketcache.combinedcache.enabled、hbase.bucketcache.ioengine和hbase.bucketcache.size。
LruBlockCache是默认的缓存,它在Java堆内存中管理。BucketCache通常使用堆外内存(off-heap),但是也可是使用文件形式(file-backed)或者堆内存(heap)。BucketCache与LruBlockCache相比,读取数据延迟要高一些,但是相对来说比较稳定,因为GC比LruBlockCache要少。因为缓存由LruBlockCache自己管理,而不是GC管理。

配置LruBlockCache

LruBlockCache默认时开启状态,由参数hfile.block.cache.size控制,取值范围0 ~ 1.0小数,表示占堆内存(heap-size)的百分比。通常MemCache和LruBlockCache之和要小于0.8,即hbase.regionserver.global.memstore.size + hfile.block.cache.size < 0.8。表示最多占用80%的堆内存,另外20%用作其他用途。

  <property>
    <name>hbase.regionserver.global.memstore.size</name>
    <value>0.4</value>
  </property>
  <!--L1读缓存-->
  <property>
    <name>hfile.block.cache.size</name>
    <value>0.4</value>
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值