如何用KyotoTycoon挂载LevelDB存储

发布时间:2022-01-17 10:22:58 作者:iii
来源:亿速云 阅读:144

这篇文章主要介绍“如何用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存储”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

推荐阅读:
  1. exsi挂载ISCSI存储出错恢复
  2. VMware:vSphere 6.5挂载NFS存储

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

kyototycoon leveldb

上一篇:Omnicore启动失败怎么办

下一篇:怎么用python画个奥运五环

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》