Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4065905
  • 博文数量: 251
  • 博客积分: 11197
  • 博客等级: 上将
  • 技术积分: 6862
  • 用 户 组: 普通用户
  • 注册时间: 2008-12-05 14:41
个人简介

@HUST张友东 work@taobao zyd_com@126.com

文章分类

全部博文(251)

文章存档

2014年(10)

2013年(20)

2012年(22)

2011年(74)

2010年(98)

2009年(27)

分类: LINUX

2011-05-20 16:07:03

BitcaskTokyo CabinetTCHDB都是基于hashkey-value存储系统,本文从两者的实现机制上进行简单的对比。

 

Bitcask: http://blog.chinaunix.net/space.php?uid=20196318&do=blog&id=154750

Tokyo Cabinet: http://blog.chinaunix.net/space.php?uid=20196318&do=blog&id=327754

 

对比项

Bitcask

TCHDB

记录存储模式

记录顺序存储,以日志的形式记录

记录可存储在任意空闲位置

 

空闲空间管理

记录始终在末尾添加,定期的进行merge操作来回收被删除记录的空间。

使用空闲块池来管理所有的空闲空间,当记录删除时回收空间,并在空闲块描述符个数超出阈值时进行连续空闲块的合并。

 

 

记录查找

hash)机制

Bitcaskhash表只存在于内存中,hash冲突采用hash链的方式,并随着系统记录的添加与移除不断更新,为了加速启动时构建hash表的效率,每个记录在添加时同时也会建立一个定长的索引记录来记录其偏移位置,Bitcask通过索引记录能快速的构建hash表。

TCHDBhash表不只存在于内存,还会存储到硬盘上,每个hash条目的值对应于该桶内第一个记录的偏移位置,其他冲突的记录通过每个记录的hash2leftright指针(相当于一颗二叉查找树)来进行查找。

 

put操作

Bitcask每次以追加写的方式添加记录,同时追加记录更新hash表,效率很高。

TCHDB每次需要查找空闲块池定位一个合适的存储区域,然后查找hash表,并要解决hash冲突(可能需要读取多个记录,并修改最后一个记录的leftright)。

 

get操作

读取hash表,并在冲突链中对比key,找到对应记录的偏移位置并读取。

读取hash表的对应的slot,如果发现key不匹配,则根据keyslotkey的大小,在冲突树上进行查找,可能需要读取出多个记录。

 

del操作

hash表和索引记录中删除对应的记录,对应的空间由merge进行回收。

hash表中删掉对应的项,如果存在hash冲突,需更改冲突树的leftright指针。

 

阅读(4576) | 评论(0) | 转发(0) |
0

上一篇:TCHDB实现机制初探

下一篇:CVT群面小结

给主人留下些什么吧!~~