Google Leveldb在Linux下的编译及在C++中的应用

本文我们主要介绍了Linux下编译Leveldb数据库的过程以及Leveldb在C++中的操作示例简介,接下来就让我们来一起了解一下这一过程。

1:简介

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

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

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,这个可以用在自己的项目中。

3:leveldb性能测试

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

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

4:leveldb头文件准备

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

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

5:示例程序

把libleveldb.a、db.h拷到本程序的同一路径下。

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

执行:

[lyc@Fedora test]$ ./sa

结果:

Open db OK

[email protected]

源码Main.cpp:

 

  1. #include <assert.h>     
  2.  
  3. #include <iostream>     
  4.  
  5. #include "db.h"     
  6.  
  7. using namespace std;    
  8.  
  9. int main(int argc,char * argv[])    
  10.  
  11. {    
  12.  
  13. leveldb::DB* db;    
  14.  
  15. leveldb::Options options;    
  16.  
  17. options.create_if_missing = true;    
  18.  
  19. std::string dbpath = "testdb";    
  20.  
  21. leveldb::Status status = leveldb::DB::Open(options, dbpath, &db);    
  22.  
  23. assert(status.ok());    
  24.  
  25. std::string key1 = "lyc";    
  26.  
  27. std::string key2 = "[email protected]";    
  28.  
  29. cout<<"Open db OK"<<std::endl;    
  30.  
  31. std::string value;    
  32.  
  33. leveldb::Status s ;    
  34.  
  35. s = db->Put(leveldb::WriteOptions(), key1, key2);/*key1和key2作为一对key-value对插入*/    
  36.  
  37. s = db->Get(leveldb::ReadOptions(), key1, &value);/*根据key返回对应的value值*/    
  38.  
  39. cout<<value<<std::endl;    
  40.  
  41. delete db;/*删除数据库*/    
  42.  
  43. return 0;    
  44.  
  45. }  

 

6:注意事项

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

6.2 Leveldb用于一些单间的数据比如名称-值对,并且数据量远大于内存并且需要***保存的情况下。很适合大规模的语言模型文件存贮。

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

关于在Linux下编译Google Leveldb数据库及在C++中操作示例就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. Oracle数据库如何创建DATABASE LINK?
  2. Oracle 10g 数据库闪回的配置与使用详解
  3. 使用connectionStrings连接SQL Server数据库
  4. 如何更改SQL Server 2005数据库中tempdb的位置
  5. 操作系统不支持SQL Server服务器组件的解决方案

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/262932.html<

(0)
运维的头像运维
上一篇2025-05-04 08:11
下一篇 2025-05-04 08:13

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注