如何用KyotoTycoon挂载LevelDB存储

网友投稿 412 2023-11-29

如何用KyotoTycoon挂载LevelDB存储

这篇文章主要介绍“如何用KyotoTycoon挂载LevelDB存储”,在日常操作中,相信很多人在如何用KyotoTycoon挂载LevelDB存储问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何用KyotoTycoon挂载LevelDB存储”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

如何用KyotoTycoon挂载LevelDB存储

  1.安装LevelDB

先获取源代码

  $svncheckouthttp://leveldb.googlecode.com/svn/trunk/leveldb-read-only

  修改Makefile,加上-fPIC选项

+CFLAGS=-c-I.-I./include$(PLATFORM_CFLAGS)$(OPT)

  -CFLAGS=-c-I.-I./include$(PLATFORM_CFLAGS)$(OPT)-fPIC

如果你用的是Ubuntu,那么再修改port/port_posix.h文件:

  +#include

  -#include

  上面几处修改完后,开始安装

  $make

$sudocplibleveldb.a/usr/local/lib

  $sudocp-rinclude/leveldb/usr/local/include

  这样LevelDB就安装完了

  2.在KC上挂载式安装LevelDB

  -最新的KC源代码,运行下面命令进行安装

$cdkyototycoon-x.y.z

  $./configure

  $make

  $sudomakeinstall

  $cdlab/leveldb

  $make

$sudocpktplugdblevel.so/usr/local/lib

  安装完成后就可以运行了

  $ktserver-pldb/usr/local/lib/ktplugdblevel.socasket.ldb

  你可以直接挂靠一些Set操作

$ktremotemgrsetjapantokyo

  $ktremotemgrsetkoreaseoul

  $ktremotemgrsetchinabeijing

  查看刚刚Set进去的数据

  $ktremotemgrlist-pv

怎样用KyotoTycoon挂载LevelDB存储

  3.插件实现

  下面附上一份挂接LevelDB的源码,其逻辑也非常简单:

  classLevelDB:publickt::PluggableDB{

  ...

boolaccept_impl(constchar*kbuf,size_tksiz,Visitor*visitor,boolwritable){

size_tlidx=kc::hashmurmur(kbuf,ksiz)%RLOCKSLOT;

  if(writable){

  rlock_.lock_writer(lidx);

  }else{

  rlock_.lock_reader(lidx);

  }

std::stringkey(kbuf,ksiz);

  std::stringvalue;

  lv::Statusstatus=db_->Get(lv::ReadOptions(),key,&value);

  constchar*rbuf;

size_trsiz;

  if(status.ok()){

  rbuf=visitor->visit_full(kbuf,ksiz,value.data(),value.size(),&rsiz);

  }else{

rbuf=visitor->visit_empty(kbuf,ksiz,&rsiz);

  }

  boolerr=false;

  if(rbuf==kc::BasicDB::Visitor::REMOVE){

lv::WriteOptionswopts;

  if(autosync_)wopts.sync=true;

  status=db_->Delete(wopts,key);

  if(!status.ok()){

set_error(_KCCODELINE_,Error::SYSTEM,"DB::Deletefailed");

  err=true;

  }

  }elseif(rbuf!=kc::BasicDB::Visitor::NOP){

lv::WriteOptionswopts;

  if(autosync_)wopts.sync=true;

  std::stringrvalue(rbuf,rsiz);

status=db_->Put(wopts,key,rvalue);

  if(!status.ok()){

  set_error(_KCCODELINE_,Error::SYSTEM,"DB::Putfailed");

  err=true;

  }

  }

rlock_.unlock(lidx);

  return!err;

  }

  ...

  };

到此,关于“如何用KyotoTycoon挂载LevelDB存储”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:如何分析redis中的高可用方案
下一篇:LevelDB的功能特性是什么
相关文章

 发表评论

暂时没有评论,来抢沙发吧~