外存 高性能 NoSQL 数据库开源项目

我要开发同款
火羽2014年12月05日
56阅读
开发技术C/C++
所属分类数据库相关、NoSQL数据库
授权协议GPL

作品详情

1.什么是外存

Exist外存本质上是一个内存级别的nosql。它提出了“面向变量”的数据访问思想,让用户只见变量,不见接口,省去了繁琐的接口调用。

以此实现了逻辑与数据分离的效果,一份单结点代码自动达到分布式效果。

目前提供了int8、uint8、uint64、float、double等基础类型变量的操作,后续将实现mapvector类型变量操作。

2.应用场景对比

来看看面向变量的接口方式比传统数据接口方式要方便多少

场景1:假设服务上有3个逻辑:用户登录时,用户发表文章,用户发表评论时,要提升用户等级。

传统数据库接口方式

申明数据库连接 db;db.connect();OnLogin(){    申明变量 level    get(表名,"level", level);    level++;    set(表名,"level", level);}OnSend(){    申明变量 level    get(表名,"level", level);    level++    set(表名,"level", level);}OnReply(){    申明变量 level    get(表名,"level", level);    level++    set(表名,"level", level);}面向变量的访问方式Exist::int32 m_var("level");//申明变量OnLogin(){    var++;//数据已经在外存服务器上修改,下次访问将在新值基础上}OnSend(){    var++;//数据已经在外存服务器上修改,下次访问将在新值基础上}OnReply(){    var++;//数据已经在外存服务器上修改,下次访问将在新值基础上}

就这么简单,用户直接看到一个个的变量,就像操作内存上的变量一样操作数据,根本不需要任何接口,外存由此得名

场景2:100万用户同时在线:用户A要查询用户B的资料

传统接口方式

m_otherNode;//其它结点/中转定位服务std::map<...> m_userList;//已经登录当前结点的用户的列表OnFindUser( char *username ){        map::iterater it = m_userList.find(username);        if ( it == m_userList.end() )//用户未必再当前结点登录,        {                m_otherNode.Send("查询用户数据");//到其它结点,或其它定位服务中专查询                m_otherNode.Recv();                if (回应用户不存在)                 {                        回应用户不存在;                        return;                }        }        回应用户信息        return;};

面向变量接口方式

Exist::map<...> m_userList;//已经登录的用户的列表,用户信息在外存上OnFindUser( char *username ){        map::iterater it = m_userList.find(username);        if ( it == m_userList.end() )//用户要么在外存中,要么不存在        {                回应,用户不存在;                return;        }        回应用户信息;        return;};

省去了到其它结点查询的代码,省去了记录相关服务的连接对象,一套代码同时满足单结点与分布式需求,从此没有分布式一说map与vector尚未实现,将在后续版本中实现,请期待

支持平台:winlinux性能:单个client测试,win5000~6000tps,linux最高达到3.7万tps支持编译:VC++6.0和VS2010,VS2010以下用户可以从VC6.0工程转换,linux直接make

欢迎各路朋友一起体验尝鲜

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论