如何在Linux下编译Google LevelDB数据库

数据库 其他数据库
Leveldb是一个google实现的非常高效的kv数据库,可按照字符串键值顺序映射进行存贮。目前的版本1.2能够支持billion级别的数据量了。 在这个数量级别下还有着非常高的性能。

1:简介

Leveldb是一个google实现的非常高效的kv数据库,可按照字符串键值顺序映射进行存贮。目前的版本1.2能够支持billion级别的数据量了。 在这个数量级别下还有着非常高的性能。

Leveldb是一个C++库,可用于很多情况。比如用于一个网页浏览器存储最近存取网页的缓存,或用于操作系统存储安装包列表,或用于应用存储用户的设置参数。其实新版本的Chrome浏览器里部署的IndexedDB HTML5 API就是基于LevelDB打造的。Google自己的数据库Bigtable掌管着数百万数据表也是用LevelDB的。

今天在Linux(Fedra14)下编译了一下,感觉不错。中间遇到了很多问题,记录下来。作为学习之用。

在这里我想发泄一下郁闷之情。我对学过Linux下的编程,但是不是很深入,大部分时间时自己摸索的,周围没有可以交流的人,再说周围的大部分在搞javaC#、.net没人在研究c\c++尤其是Linux下的。有些研究生毕业了还不知道什么是ubuntu。我以一直喜欢技术特别是Linux的,不管怎样算是一种追求吧。自己摸索之路是很坎坷的,深知一个人探索的困难,所以遇到问题会自己写下来发成博客,对自己是一种学习,也希望别的有共同兴趣的人有所帮助,如果能让没有一点基础的人们能看懂,并且根据示例自己操作成功,也算是一件很有成就感的事。

2:编译源代码

我用的版本为Release 1.2 2011-05-16,这个需要用SVN下载,过程就不多说了。

2.1 解压缩文件,我的路径是/home/lyc/leveldb/Leveldb

2.2 进入解压缩后的路径,cd /home/lyc/leveldb/Leveldb

2.3 编译,这个很简单一个命令makefile就行了,注意这个编译需要g++的支持

2.4 编译后在/home/lyc/leveldb/Leveldb路径下会出现一个库文件libleveldb.a,这个可以用在自己的项目中

3leveldb性能测试

默认的编译makefile命令是不会生成测试程序的,如果要生成这些辅助的程序,可以用命令makefile test

结果在/home/lyc/leveldb/Leveldb路径下会产生可执行文件db_bencharena_testdb_test等测试程序。这个就不解少了,我的目标的是在自己的程序中使用leveldb,所以重点在使用库文件libleveldb.a上。

4leveldb头文件准备

头文件的问题花了很多时间来解决,其实很简单,到/home/lyc/leveldb/Leveldb路径下(这个具体要根据自己的文件路径),用命令 cp -r include/leveldb   /usr/local/include。把./include/leveldb文件夹的内容都拷到/usr/local/include路径下。

注意要切还到root用户,要不没有执行的权限。

5:示例程序

libleveldb.adb.h拷到本程序的同一路径下。

编译命令为: g++ -o sa Main.cpp libleveldb.a -lpthread

执行:

[lyc@Fedora test]$ ./sa

结果:

Open db OK

liyc7711@gamil.com

源码Main.cpp:

  1. #include <assert.h> 
  2. #include <iostream> 
  3. #include "db.h" 
  4.  
  5. using namespace std; 
  6.  
  7. int main(int argc,char * argv[]) 
  8.     leveldb::DB* db; 
  9.     leveldb::Options options; 
  10.     options.create_if_missing = true
  11.     std::string dbpath = "testdb"
  12.     leveldb::Status status = leveldb::DB::Open(options, dbpath, &db); 
  13.     assert(status.ok()); 
  14.     std::string key1 = "lyc"
  15.     std::string key2 = "liyc7711@gamil.com"
  16.     cout<<"Open db OK"<<std::endl; 
  17.      
  18.     std::string value; 
  19.     leveldb::Status s ; 
  20.     s = db->Put(leveldb::WriteOptions(), key1, key2);/*key1和key2作为一对key-value对插入*/ 
  21.     s = db->Get(leveldb::ReadOptions(), key1, &value);/*根据key返回对应的value值*/ 
  22.      
  23.     cout<<value<<std::endl; 
  24.     delete db;/*删除数据库*/ 
  25.  
  26.     return 0; 

6:注意事项

6.1 编译中加上库文件的路径(libleveldb.a)和线程库标志(-lpthread),执行后在当前文件产生一个文件夹testdb保存了插入的数据。

6.2 leveldb值对,并且数据量远大于内存并且需要永久保存的情况下。很适合大规模的语言模型文件存贮。

6.3 插入的数据为两个字符串对一个为key,另外一个为value,查询时可以根据key取得value的值,相反不可以。

【编辑推荐】

  1. LevelDB性能分析和表现
  2. LevelDB—一个超高性能的K/V数据库
  3. 浅谈LevelDB在ubuntu 11.04下编译失败的问题
责任编辑:艾婧 来源: 李亚超的专栏
相关推荐

2011-08-09 15:47:46

LeveldbLinuxC++

2017-08-07 16:41:39

LinuxOpenCV

2022-11-24 12:00:20

UbuntuLinux

2010-08-12 13:32:08

DB2数据库备份

2010-04-19 13:15:00

Oracle数据库

2009-08-12 18:16:37

Oracle数据库自动UNIX

2010-05-06 10:52:36

Oracle9i

2017-12-11 10:24:29

LinuxGoogleChrome 63

2009-07-07 14:56:33

JSP连接MySQL

2011-07-26 14:34:28

openSUSEpostgresql

2019-08-19 14:06:27

MySQLDocker数据库

2009-06-01 09:57:43

netbeans连接数netbeans数据库netbeans连接m

2023-09-05 08:40:57

删除数据库Oracle

2011-08-17 17:29:32

Windows编译MySQL

2011-10-08 13:22:43

Google数据库云计算

2011-06-09 09:32:13

LevelDB

2011-03-03 10:00:14

ProFTPD建立MySQL

2009-01-19 09:14:31

.NETMySQLMySql驱动包

2021-12-03 23:21:45

数据库MySQLKubernetes

2011-04-07 15:02:02

LinuxMySQL数据库
点赞
收藏

51CTO技术栈公众号