LevelDB源码分析-第一印象
2015-02-09 18:07
183 查看
leveldb是google开源的nosql数据库,被很多人推荐,因为良好的C++代码格式,咱们试图来分析一下吧
从github下载源码,代码量不是很大,而且目录结构也很清晰,咱们先写一下入门程序,来熟悉一下基本用法
上面的代码包含了基本用法,包括打开,关闭,写入,读出,snapshot,iterator,等基本操作,可以看到google的命名规则.
Google C++ Style Guide
http://www.cnblogs.com/chlyzone/archive/2011/04/09/2010455.html
实现简要
leveldb是根据big table的思想来做的,所以咱们还需要理解一下bigtable是怎么回事,当然我也不懂..慢慢来吧
从github下载源码,代码量不是很大,而且目录结构也很清晰,咱们先写一下入门程序,来熟悉一下基本用法
leveldb::DB* db; leveldb::Options options; options.create_if_missing = true; leveldb::Status status = leveldb::DB::Open(options,"/tmp/testdb",&db); assert(status.ok()); status = db->put(leveldb::WriteOptions(),"name","phgame"); assert(status.ok()); status = db->get(leveldb::ReadOptions(),"name",&value); assert(status.ok()); leveldb::ReadOptions readoptions; readoptions.snapshot = db->getSnapshot(); leveldb::Iterator* itor = db->NewIterator(readoptions); for(iter->SeekToFirst();iter->Valid();iter->Next()){ std::out<<iter->key().ToString()<<" :" <<iter->value().ToString(); db->ReleaseSnapshot(readoptions.snapshot); delete db;
上面的代码包含了基本用法,包括打开,关闭,写入,读出,snapshot,iterator,等基本操作,可以看到google的命名规则.
Google C++ Style Guide
http://www.cnblogs.com/chlyzone/archive/2011/04/09/2010455.html
实现简要
leveldb是根据big table的思想来做的,所以咱们还需要理解一下bigtable是怎么回事,当然我也不懂..慢慢来吧
相关文章推荐
- LevelDB源码分析之内存管理类arena
- LevelDB源码分析之十四:TwoLevelIterator
- levelDB-Java源码分析
- leveldb源码分析--SSTable之TableBuilder
- LevelDB源码分析2-整数编解码
- levelDB源码分析-Slice
- levelDB源码分析-SSTable:.sst文件构建与读取
- Leveldb源码分析--17
- u-boot源码分析第一阶段之Start.S
- leveldb源码分析之五
- leveldb源码分析:Cache
- uboot源码分析1-启动第一阶段
- leveldb源码分析--WriteBatch
- leveldb源码分析--Comparator
- Leveldb源码分析--4
- hdfs源码分析第一弹
- levelDB源码分析-Status
- Leveldb源码分析--1
- Leveldb源码分析--2
- 【转载】leveldb源码分析—Recover和Repair