温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

本地memstore怎么分配缓冲区

发布时间:2021-07-27 22:43:49 来源:亿速云 阅读:108 作者:chen 栏目:云计算

本篇内容介绍了“本地memstore怎么分配缓冲区”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、 生存期长的keyvalue实例刷写到磁盘中--》老生代堆上生成孔洞-》孔洞越来越多,无法足够大的连续空间分配-》JRE使用 stop-the-world垃圾回收器-》重写整个堆空间,并压缩剩余可用对象

二、 解决以上问题的方法 :

  0.92版本后使用 本地memstore分配缓冲区(memstore-local allocation buffer) MSLAB

  即,从堆中分配同样大小的对象,当最终被回收时,堆中将留下固定大小的孔洞。

三、配置文件中 配置:

  1 通过hbase.hregion.memstore.mslab.enabled 来配置

  2 分配缓冲区大小:hbase.hregion.memstore.mslab.chunksize ,默认是2M,且是合理的。

    根据自己的keyvalue实例大小来调整。

  3 存储缓冲区上边界:hbase.hregion.memstore.mslab.max.allocation 属性,默认256kb,

    超过这个值,直接在java堆中申请空间。

四 优缺点:

   优点:推迟垃圾回收停顿的发生 

   缺点:1 浪费堆空间,不能充分利用

            2 使用缓冲区需要额外的内存复制工作,比直接使用keyvalues实例

“本地memstore怎么分配缓冲区”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI