千家信息网

如何用KyotoTycoon挂载LevelDB存储

发表于:2024-11-11 作者:千家信息网编辑
千家信息网最后更新 2024年11月11日,这篇文章主要介绍"如何用KyotoTycoon挂载LevelDB存储",在日常操作中,相信很多人在如何用KyotoTycoon挂载LevelDB存储问题上存在疑惑,小编查阅了各式资料,整理出简单好用的
千家信息网最后更新 2024年11月11日如何用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存储"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

0