您好,登錄后才能下訂單哦!
本篇內容介紹了“本地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怎么分配緩沖區”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。