学习flush与split时所遇的问题

因为region中的值都是以key来排序的,但是flush操作是生成一个新Store file(HFile),那么还怎么保持region中key的有序呢?

然后又延伸出一个问题:flush操作生成的Store file,为什么大小不一?见下图(与compaction有关)

原因是:

flush是对一个HRegion来定义的,所以flush时,是对其所有的Store里的MemStore进行flush . 即有可能会flush出多个文件,对应在不同的Store里,这样就解释了为什么大小不一。
 
那么这么多storefile,怎么保持region中key有序呢,答案是:keyvalue是以storefile为排序的单位的。即每个storefile都是按照key来排序的,但同一系列的key可能在不同storefile,compaction过程中也保持了key的有序。查找的话是一个storefile,一个storefile这样查找的。
 
我们都知道region的split是将split一分为二,那么它在storefile层次是如何切分的呢?答案是它把所有的storefile也一分为二。

转载于:https://www.cnblogs.com/zxpgo/archive/2012/12/05/2803497.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值