leveldb的搜索

Posted Math & Code & Wave

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leveldb的搜索相关的知识,希望对你有一定的参考价值。

 

参考:

http://taobaofed.org/blog/2017/07/05/leveldb-analysis/

和leveldb源码(block.cc的Seek函数)。

 

leveldb的key、value是放在一起的,可以scan,但不会直接搜索的,而和搜索相关的是,bloom filter和restarts。

 

bloom filter用来快速确定某个key是否存在,有意思的是,leveldb用了多个bloom filter,这样可以多次判定。

 

和想象的一样,leveldb用了二分搜索。leveldb的key本来是压缩的,但是也有不压缩的key,一般是间隔几个就不压缩,并用restarts记录offset。leveldb的key是有序的,所以用二分搜索restarts,就可以找到key的存在。

 

以上是关于leveldb的搜索的主要内容,如果未能解决你的问题,请参考以下文章

未加载库:@rpath/leveldb.framework/leveldb

[LevelDB] LevelDB之WriteBatch

LevelDB 在删除 LevelDB 实例时断言

leveldb 源码--总体架构分析

Leveldb学习笔记:leveldb的使用与原理探究

Leveldb学习笔记:leveldb的使用与原理探究