LevelDB使用入门
2016-10-03 12:17:59 doc_sgl 阅读数 9544更多
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/doc_sgl/article/details/52727475
1,下载levelDB源码
git clone https://github.com/google/leveldb.git
2,编译LevelDB
cd leveldb & make all
编译完成之后在当前目录多了两个目录:out-shared和out-static
在out-static目录下有我们需要的libleveldb.a
3,在当前目录新建文件夹test
touch test; cd test
4,在test目录新建测试代码test.cpp
-
#include <assert.h>
-
#include <string.h>
-
#include <iostream>
-
#include "leveldb/db.h"
-
int main(){
-
leveldb::DB* db;
-
leveldb::Options options;
-
options.create_if_missing = true;
-
leveldb::Status status = leveldb::DB::Open(options,"/tmp/testdb", &db);
-
assert(status.ok());
-
std::string k1 = "name";
-
std::string v1 = "jim";
-
status = db->Put(leveldb::WriteOptions(), k1, v1);
-
assert(status.ok());
-
status = db->Get(leveldb::ReadOptions(), k1, &v1);
-
assert(status.ok());
-
std::cout<<"k1:"<<k1<<"; v1:"<<v1<<std::endl;
-
std::string k2 = "age";
-
std::string v2 = "20";
-
status = db->Put(leveldb::WriteOptions(), k2, v2);
-
assert(status.ok());
-
status = db->Get(leveldb::ReadOptions(), k2, &v2);
-
assert(status.ok());
-
std::cout<<"k2:"<<k2<<"; v2:"<<v2<<std::endl;
-
status = db->Delete(leveldb::WriteOptions(), k2);
-
assert(status.ok());
-
std::cout<<"Delete k2.."<<std::endl;
-
status = db->Get(leveldb::ReadOptions(),k2, &v2);
-
if(!status.ok())
-
std::cerr<<"k2:"<<k2<<"; "<<status.ToString()<<std::endl;
-
else
-
std::cout<<"k2:"<<k2<<"; v2:"<<v2<<std::endl;
-
delete db;
-
return 0;
-
}
5,编译前的准备
把libleveldb.a拷贝到当前目录
cp ../out-static/libleveldb.a ./
把leveldb/include目录添加到PATH :
cd ..; export PATH=$PATH:$(pwd)/include; cd test
6,编译运行
编译:
g++ -o test test.cpp libleveldb.a -lpthread -I../include
运行:
-
➜ test git:(master) ✗ ./test
-
k1:name; v1:jim
-
k2:age; v2:20
-
Delete k2..
-
k2:age; NotFound:
到目前为止,我们就基本可以使用leveldb了。
9, 执行完.test之后,在/tmp/testdb下面产生了leveldb相关的文件:
-
➜ test git:(master) ✗ ls -alh /tmp/testdb
-
total 56
-
drwxr-xr-x 10 root wheel 340B 10 3 12:51 .
-
drwxrwxrwt 14 root wheel 476B 10 3 12:31 ..
-
-rw-r--r-- 1 root wheel 148B 10 3 12:14 000005.ldb
-
-rw-r--r-- 1 root wheel 148B 10 3 12:51 000008.ldb
-
-rw-r--r-- 1 root wheel 80B 10 3 12:51 000009.log
-
-rw-r--r-- 1 root wheel 16B 10 3 12:51 CURRENT
-
-rw-r--r-- 1 root wheel 0B 10 3 11:57 LOCK
-
-rw-r--r-- 1 root wheel 309B 10 3 12:51 LOG
-
-rw-r--r-- 1 root wheel 309B 10 3 12:14 LOG.old
-
-rw-r--r-- 1 root wheel 110B 10 3 12:51 MANIFEST-000007
8, 根据LevelDB官方网站的描述,LevelDB的特点和限制如下:
特点:
1、key和value都是任意长度的字节数组;
2、entry(即一条K-V记录)默认是按照key的字典顺序存储的,当然开发者也可以重载这个排序函数;
3、提供的基本操作接口:Put()、Delete()、Get()、Batch();
4、支持批量操作以原子操作进行;
5、可以创建数据全景的snapshot(快照),并允许在快照中查找数据;
6、可以通过前向(或后向)迭代器遍历数据(迭代器会隐含的创建一个snapshot);
7、自动使用Snappy压缩数据;
8、可移植性;
限制:
1、非关系型数据模型(NoSQL),不支持sql语句,也不支持索引;
2、一次只允许一个进程访问一个特定的数据库;
3、没有内置的C/S架构,但开发者可以使用LevelDB库自己封装一个server;